cxf 调用 webservice服务时传递 服务器验证需要的用户名密码

cxf通过wsdl2java生成客户端调用webservice时,如果服务器端需要通过用户名和密码验证,则客户端必须传递验证所必须的用户名和密码,刚开始想通过url传递用户名和密码,于是在wsdl文件中直接在<soap:address location 标记中添加加入用户名和密码,但是webservice接收不到参数,此种方法行不通。后来在接口方法调用前用BindingProvider 得到RequestContext,在其中设置了请求需要的用户名和密码,接口顺利通过验证,执行成功,具体代码如下:

/**
	 * 根据给定的参数执行接口程序
	 * 
	 * @param request
	 * @return
	 */
	public ZPILOT01SSOCMMIF001CONResponse executeService(
			ZPILOT01SSOCMMIF001CON request) throws Exception {

		// 得到本地服务类
		MIZPILOT01SSOCMMIF001CONOutSynService service = new MIZPILOT01SSOCMMIF001CONOutSynService();

		// 得到接口的代理
		MIZPILOT01SSOCMMIF001CONOutSyn stub = service
				.getMIZPILOT01SSOCMMIF001CONOutSynPort();

		// 设置访问接口服务器的用户名和密码
		BindingProvider bp = (BindingProvider) stub;
		Map<String, Object> context = bp.getRequestContext();
		context.put(BindingProvider.USERNAME_PROPERTY, XI_USER_NAME);
		context.put(BindingProvider.PASSWORD_PROPERTY, XI_PASSWORD);

		// 执行接口
		ZPILOT01SSOCMMIF001CONResponse response = stub
				.miZPILOT01SSOCMMIF001CONOutSyn(request);

		// 返回响应
		return response;
	}

 

你可能感兴趣的:(webservice)