ws+xfire实现安全的web服务请求

本文详细介绍了如何在web服务中进行配置信息初始化和文件环境的准备,包括使用RepositoryDataInitImpl类创建RepositoryModel实例,并对其进行关键属性设置,如组织ID、密码、安全性信息等。此外,还涉及到.properties和.jks文件的生成过程,确保了服务的安全性和稳定性。
配置信息初始化和文件环境的准备

public class RepositoryDataInitImpl implements RepositoryDataInit
{
public List initData(ServletContextEvent sce)
{
RepositoryData repositoryData=new RepositoryDataImpl();
List list=(List)repositoryData.getRepositoryData();
List repositoryList=new ArrayList();
for(int i=0;i<=list.size()-1;i++)
{
RepositoryModel repositoryModel=new RepositoryModel();
Object[] o =(Object[])list.get(i);
EBizOrg eBizOrg=(EBizOrg)o[0];
EBizOrgService eBizOrgService=(EBizOrgService)o[1];
repositoryModel.setOrgId(eBizOrg.getOrgId());
repositoryModel.setPassWord(eBizOrg.getUserPwd());
repositoryModel.setSecurityInfo(eBizOrg.getSecurityInfo());
repositoryModel.setUrl(eBizOrg.getServeAddress()+eBizOrgService.getServiceInterface());
repositoryModel.setUserName(eBizOrg.getAccessUser());
repositoryModel.setServiceName(eBizOrgService.getId().getServiceName());
repositoryModel.setServiceInterface(eBizOrgService.getServiceInterface());
repositoryModel.setServiceClass(eBizOrgService.getServiceClass());
repositoryModel.setKeyFile(eBizOrg.getKeyFile());
repositoryModel.setJksPwd(eBizOrg.getJksPwd());
repositoryList.add(repositoryModel);

createProperties(repositoryModel,sce);//.properties文件产生(转移,导入?)
createKeyFile(repositoryModel, sce);//.jks文件产生(转移,导入?)
}
return repositoryList;
}

public void createKeyFile(RepositoryModel repositoryModel,ServletContextEvent sce)
{
String path=sce.getServletContext().getRealPath("/")+"WEB-INF\\classes\\com\\key\\xfire\\";
OutputStream out = null;
InputStream fin=null;
try {
out = new FileOutputStream(path+repositoryModel.getOrgId().trim()+".jks");
fin = repositoryModel.getKeyFile().getBinaryStream();
System.out.println(repositoryModel.getOrgId().trim()+".jks" +":"+ fin.available());
int firstChar = fin.read();
int length = fin.available();

//将其转换成二进制数据
byte[] data = new byte[length+1];
data[0] = (byte)firstChar;
int len=0;
while (( len= fin.read(data,1,length+1)) != -1)
{
out.write(data, 0, len+1);
}
fin.close();
out.flush();
out.close();

} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

public void createProperties(RepositoryModel repositoryModel,ServletContextEvent sce)
{
String path=sce.getServletContext().getRealPath("/")+"WEB-INF\\classes\\"+repositoryModel.getSecurityInfo();
path=path.replaceAll("/", "\\\\");
Properties prop=new Properties();
try{
File f=new File(path);
f.createNewFile();
FileInputStream in=new FileInputStream(path);
prop.load(in);
in.close();
prop.setProperty("org.apache.ws.security.crypto.provider", "org.apache.ws.security.components.crypto.Merlin");
prop.setProperty("org.apache.ws.security.crypto.merlin.keystore.type", "jks");
prop.setProperty("org.apache.ws.security.crypto.merlin.keystore.password", repositoryModel.getJksPwd().trim());
prop.setProperty("org.apache.ws.security.crypto.merlin.file", "com/key/xfire/"+repositoryModel.getOrgId().trim()+".jks");
try {
prop.store(new FileOutputStream(path), null);
} catch (IOException e) {}
}
catch(Exception e)
{
System.out.print(e.getMessage());
}
}

public Map initAccount(List list)
{
Map<String, String> passwords= new HashMap<String, String>();
for(int i=0;i<list.size();i++)
{
RepositoryModel repositoryModel =(RepositoryModel)list.get(i);
passwords.put(repositoryModel.getUserName().trim(), repositoryModel.getPassWord().trim());
}
return passwords;
}

public List setRepository(String key,ServletContextEvent sce)
{
String[] temp=key.split("-");
RepositoryData repositoryData=new RepositoryDataImpl();
List list=(List)repositoryData.getNewRepositoryData(temp[0],temp[1]);
List repositoryList=new ArrayList();
for(int i=0;i<=list.size()-1;i++)
{
RepositoryModel repositoryModel=new RepositoryModel();
Object[] o =(Object[])list.get(i);
EBizOrg eBizOrg=(EBizOrg)o[0];
EBizOrgService eBizOrgService=(EBizOrgService)o[1];

repositoryModel.setOrgId(eBizOrg.getOrgId());
repositoryModel.setPassWord(eBizOrg.getUserPwd());
repositoryModel.setSecurityInfo(eBizOrg.getSecurityInfo());
repositoryModel.setUrl(eBizOrg.getServeAddress()+eBizOrgService.getServiceInterface());
repositoryModel.setUserName(eBizOrg.getAccessUser());
repositoryModel.setServiceName(eBizOrgService.getId().getServiceName());
repositoryModel.setServiceInterface(eBizOrgService.getServiceInterface());
repositoryModel.setServiceClass(eBizOrgService.getServiceClass());
repositoryModel.setKeyFile(eBizOrg.getKeyFile());
repositoryModel.setJksPwd(eBizOrg.getJksPwd());
repositoryList.add(repositoryModel);
createProperties(repositoryModel,sce);
createKeyFile(repositoryModel, sce);
}

return repositoryList;
}

public Map setAccount(List list)
{
Map<String, String> passwords= new HashMap<String, String>();
for(int i=0;i<list.size();i++)
{
RepositoryModel repositoryModel =(RepositoryModel)list.get(i);
passwords.put(repositoryModel.getUserName().trim(), repositoryModel.getPassWord().trim());
}
return passwords;
}
}


web服务类的注册


public class ObjectRepositoryImpl implements ObjectRepository
{
private static Map<String, Object> serviceContainer = new HashMap<String, Object>();
private static Map<String, String> passwords=new HashMap<String, String>();
public List data;

private static ServletContextEvent sce;

public static Map<String, Object> getServiceContainer() {
return serviceContainer;
}

public static void setServiceContainer(Map<String, Object> serviceContainer) {
ObjectRepositoryImpl.serviceContainer = serviceContainer;
}

public List getData() {
return data;
}

public void setData(List data) {
this.data = data;
}
@SuppressWarnings("unchecked")
public void init(ServletContextEvent sce)
{
if (!ObjectRepositoryImpl.serviceContainer.isEmpty())
{
ObjectRepositoryImpl.serviceContainer.clear();
}
if (!ObjectRepositoryImpl.passwords.isEmpty())
{
ObjectRepositoryImpl.passwords.clear();
}
data=new ArrayList();
RepositoryDataInit repositoryDataInit=new RepositoryDataInitImpl();
data= repositoryDataInit.initData(sce);
this.passwords=repositoryDataInit.initAccount(data);//data包括了.jks里面的storepass
this.sce=sce;

}


public void repository()
{
for (int i=0;i<data.size();i++)
{
RepositoryModel repositoryModel=(RepositoryModel)data.get(i);
createRepository(repositoryModel);
}
}

public void createRepository(RepositoryModel repositoryModel)
{
try {
String url=repositoryModel.getUrl();
String userName=repositoryModel.getUserName();
String path=repositoryModel.getSecurityInfo();
String orgId=repositoryModel.getOrgId();
String serviceName=repositoryModel.getServiceName();
String serviceClass=repositoryModel.getServiceClass();
//String serviceName="com.saleTicket.service.SaleTicketService";
//产生对象引用
Service srvcModel=null;
XFireProxyFactory factory = new XFireProxyFactory(XFireFactory.newInstance().getXFire());

Class cls = null;
try {
cls = Class.forName(serviceClass);
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
srvcModel = new ObjectServiceFactory().create(cls);
Object o=(Object)factory.create(srvcModel,url);
Client client =null;
client = ((XFireProxy)Proxy.getInvocationHandler(o)).getClient();
regSecurity(client,userName,path);
serviceContainer.put(orgId+"-"+serviceName,o);
}
catch (MalformedURLException e) {
e.printStackTrace();
}
}


public void regSecurity(Client client,String userName,String path)
{
client.addOutHandler(new DOMOutHandler());
Properties properties =new Properties();
properties.setProperty(WSHandlerConstants.ACTION,WSHandlerConstants.SIGNATURE);
properties.setProperty(WSHandlerConstants.USER, userName);
properties.setProperty(WSHandlerConstants.PW_CALLBACK_CLASS,PasswordHandler.class.getName());
properties.setProperty(WSHandlerConstants.SIG_PROP_FILE,path);
properties.setProperty(WSHandlerConstants.SIG_KEY_ID,"IssuerSerial");
client.addOutHandler(new WSS4JOutHandler(properties));

long timeout = 2000;
HttpClientParams params = new HttpClientParams();
// 避免'Expect: 100-continue' handshake
params.setParameter(HttpClientParams.USE_EXPECT_CONTINUE,Boolean.FALSE);
//设置ws连接超时时间
params.setParameter(HttpClientParams.CONNECTION_MANAGER_TIMEOUT, timeout);
//client.setTimeout(5000);
client.setProperty(CommonsHttpMessageSender.HTTP_CLIENT_PARAMS,params);
}

public Object getService(String serviceId,boolean flag)
{
String key = serviceId;
Object obj =serviceContainer.get(key);
if (obj==null)
{
RepositoryDataInit repositoryDataInit=new RepositoryDataInitImpl();
List list= repositoryDataInit.setRepository(key,sce);
for(int i=0 ;i<list.size();i++)
{
RepositoryModel repositoryModel=(RepositoryModel)list.get(i);
createRepository( repositoryModel);
}
passwords.putAll(repositoryDataInit.initAccount(list));
obj =serviceContainer.get(key);
}
return obj;
}

public static void setPasswords(Map<String, String> passwords)
{
ObjectRepositoryImpl.passwords = passwords;
}



public static Map<String, String> getPasswords() {
return passwords;
}
}


调用web服务

public SaleTicketService getServiceHandle(String ycNo)
{
ObjectRepositoryImpl objectRepositoryImpl=new ObjectRepositoryImpl();
Object o=objectRepositoryImpl.getService(ycNo,true);
SaleTicketService srvc=(SaleTicketService)o;
return srvc;
}
采用PyQt5框架与Python编程语言构建图书信息管理平台 本项目基于Python编程环境,结合PyQt5图形界面开发库,设计实现了一套完整的图书信息管理解决方案。该系统主要面向图书馆、书店等机构的日常运营需求,通过模块化设计实现了图书信息的标准化管理流程。 系统架构采用典型的三层设计模式,包含数据存储层、业务逻辑层和用户界面层。数据持久化方案支持SQLite轻量级数据库与MySQL企业级数据库的双重配置选项,通过统一的数据库操作接口实现数据存取隔离。在数据建模方面,设计了包含图书基本信息、读者档案、借阅记录等核心数据实体,各实体间通过主外键约束建立关联关系。 核心功能模块包含六大子系统: 1. 图书编目管理:支持国际标准书号、中国图书馆分类法等专业元数据的规范化著录,提供批量导入与单条录入两种数据采集方式 2. 库存动态监控:实时追踪在架数量、借出状态、预约队列等流通指标,设置库存预警阈值自动提醒补货 3. 读者服务管理:建立完整的读者信用评价体系,记录借阅历史与违规行为,实施差异化借阅权限管理 4. 流通业务处理:涵盖借书登记、归还处理、续借申请、逾期计算等标准业务流程,支持射频识别技术设备集成 5. 统计报表生成:按日/月/年周期自动生成流通统计、热门图书排行、读者活跃度等多维度分析图表 6. 系统维护配置:提供用户权限分级管理、数据备份恢复、操作日志审计等管理功能 在技术实现层面,界面设计遵循Material Design设计规范,采用QSS样式表实现视觉定制化。通过信号槽机制实现前后端数据双向绑定,运用多线程处理技术保障界面响应流畅度。数据验证机制包含前端格式校验与后端业务规则双重保障,关键操作均设有二次确认流程。 该系统适用于中小型图书管理场景,通过可扩展的插件架构支持功能模块的灵活组合。开发过程中特别注重代码的可维护性,采用面向对象编程范式实现高内聚低耦合的组件设计,为后续功能迭代奠定技术基础。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值