DWR调用Acegi登录接口所遇到的问题

本文讨论了一个使用Acegi进行登录认证的系统,在引入JQuery和DWR实现无刷新操作后遇到的问题。具体表现为登录状态未被正确传递导致用户体验不佳。文中探讨了通过DWR调用Acegi接口的尝试及其限制,并提出了一种绕过方案。

当前系统登录是由Acegi控制, 通常是弹出JSP的登录页面,再由JSP中Form向Acegi提交登录请求“j_security_check”,去获取登录及授权认证。

 

这样的流程基于页面流控制一直没有问题, 直到新的需求出现。 新需求, 为了用户的体验友好,不采用之前的页面流完成业务,而是采用JQuery和Dwr在同一页面完成。

 

新问题出现, 之前的登录流程,当用户登录成功,会刷新当前页面,但是按新需求,当用户点击歌曲列表,再点击歌曲播放,点击当前歌曲评论,发现用户未登录,提示让用户登录,页面刷新后,会直接显示歌曲列表,而不会歌曲评论。

 

按新需求想将调用Acegi登录接口写成DWR方法可供调用,参考了网上可搜索到的资料:

 

HttpClient client = new HttpClient();  

client.getHostConfiguration().setHost(LOGON_SITE, LOGON_PORT);      

 

PostMethod post = new PostMethod("http://xxx.xxx.xxx:8080/hudson/j_acegi_security_check");  

 

NameValuePair name = new NameValuePair( "j_username" , "xxxx" );  

NameValuePair pass = new NameValuePair( "j_password" , "xxxxx" );  

 

post.setRequestBody(new NameValuePair[] { name, pass });  

int status = client.executeMethod(post);  

post.releaseConnection();  

 

发现这样做之后,虽然能获取用户登录成功后的提示信息,但是却不在同一个Session里,无法获取到当前用户的登录后授取信息。

 

这个与需求不符, 最后的解决方案是, 由VC客户端调用之前的WEB登录页面,获取到用户的登录信息后,写入到JS方法里,再由歌曲评论的JS方法调用。

 

希望能找到解决方案。。。。。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值