http://blog.csdn.net/binyao02123202/article/details/12204411
1、软件下载
Oauth服务端: http://code.google.com/p/oauth/
通过SVN,下载源码。
或者下载站长整合好的示例源码:http://115.com/file/aqvpzqhz
客户端下载:http://code.google.com/p/oauth-signpost/ oauth-signpost
或者下载站长整合好的示例源码:http://115.com/file/bhy1d2ce
2、服务端源码下载后,把相关代码整合在一起(或直接下载站长整合好的代码),修改net.oauth.provider.core.SampleOAuthProvider 类,把从 provider.properties 读取的信息改为从数据库中读取,如APP_KEY、APP_SCERET、描述、回调地址。
3、net.oauth.example.provider.servlets下面的四个类,这里对应着oauth3个请求url,跟一个用于测试的链接,可以根据需求修改,如将调用Oauth的用户信息记录下来。
4、修改web.xml 增加三个请求url
02 |
< servlet-name >request_token</ servlet-name > |
03 |
< servlet-class >net.oauth.provider.servlets.RequestTokenServlet</ servlet-class > |
06 |
< servlet-name >request_token</ servlet-name > |
07 |
< url-pattern >/oauth/request_token</ url-pattern > |
11 |
< servlet-name >access_token</ servlet-name > |
12 |
< servlet-class >net.oauth.provider.servlets.AccessTokenServlet</ servlet-class > |
15 |
< servlet-name >access_token</ servlet-name > |
16 |
< url-pattern >/oauth/access_token</ url-pattern > |
20 |
< servlet-name >authorize</ servlet-name > |
21 |
< servlet-class >net.oauth.provider.servlets.AuthorizationServlet</ servlet-class > |
24 |
< servlet-name >authorize</ servlet-name > |
25 |
< url-pattern >/oauth/authorize</ url-pattern > |
5、做个拦截器,只要通过某url访问的都需要进行Oauth认证:
web.xml
2 |
< filter-name >OauthFilter</ filter-name > |
3 |
< filter-class >web.school.phone.OauthFilter</ filter-class > |
6 |
< filter-name >OauthFilter</ filter-name > |
7 |
< url-pattern >/phone/*</ url-pattern > |
web.school.phone.OauthFilter
01 |
package web.school.phone; |
02 |
import java.io.IOException; |
04 |
import javax.servlet.Filter; |
05 |
import javax.servlet.FilterChain; |
06 |
import javax.servlet.FilterConfig; |
07 |
import javax.servlet.ServletException; |
08 |
import javax.servlet.ServletRequest; |
09 |
import javax.servlet.ServletResponse; |
10 |
import javax.servlet.http.HttpServletRequest; |
11 |
import javax.servlet.http.HttpServletResponse; |
13 |
import net.oauth.OAuthAccessor; |
14 |
import net.oauth.OAuthMessage; |
15 |
import net.oauth.provider.core.SampleOAuthProvider; |
16 |
import net.oauth.server.OAuthServlet; |
18 |
public class OauthFilter implements Filter
{ |
20 |
public void destroy()
{ |
23 |
public void init(FilterConfig
fConfig) throws ServletException
{ |
26 |
public void doFilter(ServletRequest
request, ServletResponse response, FilterChain chain) |
27 |
throws IOException,
ServletException { |
28 |
HttpServletRequest
req=(HttpServletRequest)request; |
29 |
HttpServletResponse
res=(HttpServletResponse)response; |
32 |
OAuthMessage
requestMessage = OAuthServlet.getMessage(req, null ); |
33 |
OAuthAccessor
accessor = SampleOAuthProvider.getAccessor(requestMessage); |
34 |
SampleOAuthProvider.VALIDATOR.validateMessage(requestMessage,
accessor); |
36 |
System.out.println( "[OauthFilter:passed]:" +req.getRequestURI()); |
37 |
chain.doFilter(request,
response); //验证通过则转向 |
39 |
} catch (Exception
e){ |
41 |
SampleOAuthProvider.handleException(e,
req, res, false ); |
6、执行客户端代码,提示输入验证码时,把控制台打印的URL放到浏览器里打开,输入授权码:
(服务端AuthorizationServlet 里面修改验证不通过要跳转的页面,页面上会打印一些参数)
- 一步一步搭建 OAuth 认证服务器
http://www.fising.cn/2011/03/%E4%B8%80%E6%AD%A5%E4%B8%80%E6%AD%A5%E6%90%AD%E5%BB%BA-oauth-%E8%AE%A4% ...
- 家用环境下部署wifidog认证服务器(java版)
本文所讲的是基于一个java版wifidog认证服务器的开源项目,在windows环境下搭建wifidog认证服务器配合apfree固件实现用户名密码的认证. 大致步骤如下: 一,准备 1.搭建硬件及 ...
- oauth2使用心得-----基本概念以及认证服务器搭建
应用场景 我们假设你有一个“云笔记”产品,并提供了“云笔记服务”和“云相册服务”,此时用户需要在不同的设备(PC.Android.iPhone.TV.Watch)上去访问这些“资源”(笔记,图片) 那 ...
- 拿nodejs快速搭建简单Oauth认证和restful API server攻略
拿nodejs快速搭建简单Oauth认证和restful API server攻略:http://blog.csdn.net/zhaoweitco/article/details/21708955 最 ...
- authpuppy 认证服务器搭建
此文仅限于搭建authpuppy认证服务器,不包含认证插件等安装,仅说明步骤以备下次安装忘记步骤.耽误时间. 环境:ubuntu10.04 软件版本:authpuppy-1.0.0-stable.tg ...
- Spring cloud微服务安全实战-4-5搭建OAuth2认证服务器
现在可以访问我们的认证服务器,应用我们已经配置好了. 下面配置让用户可以访问我的认证服务器.再来重写一个方法. EndpointConfigure端点的配置. authenticationManage ...
- 阶段5 3.微服务项目【学成在线】_day16 Spring Security Oauth2_05-SpringSecurityOauth2研究-搭建认证服务器
3 Spring Security Oauth2研究 3.1 目标 本项目认证服务基于Spring Security Oauth2进行构建,并在其基础上作了一些扩展,采用JWT令牌机制,并自定 义了用 ...
- 学习Spring Security OAuth认证(一)-授权码模式
一.环境 spring boot+spring security+idea+maven+mybatis 主要是spring security 二.依赖 <dependency> <g ...
- OAuth认证协议原理分析及同步消息到Twitter和Facebook使用方法
OAuth有什么用?为什么要使用OAuth? twitter或豆瓣用户一定会发现,有时候,在别的网站,点登录后转到 twitter登录,之后转回原网站,你会发现你已经登录此网站了,这种网站就是这个效果 ...
随机推荐
- 【转】linux /usr/bin/ld cannot find 解决
原文网址:http://blog.csdn.net/mzwang123/article/details/6702889 问题:在linux环境编译应用程式或lib的source code时常常会出现如 ...
- 可视化zookeeper的事务日志(转)
前面提到,在zookeeper server的配置文件zoo.cfg中可以通过dataLogDir来配置zookeeper的事务日志的输出目录,这个事务日志类似于下面这样的文件: 这个文件是一个二进制 ...
- Bootstrap之表格checkbox复选框全选 [转]
转自: http://blog.csdn.net/shangmingchao/article/details/49761315 效果图: HTML中无需添加额外的一列来表示复选框,而是由JS完成,所以 ...
- 编译 skia
0.准备工作 在 https://android.googlesource.com/ 用 git 代码,当然也可以从skia的官方https://code.google.com/p/skia/ 中获取 ...
- 单调栈 二 nyOj 最大矩形和
主要思想来自 http://blog.csdn.net/wuyanyi/article/details/7243580 题目的连接,头次提交的同学需要注册 http://acm.nyist.net/J ...
- input子系统分析
------------------------------------------ 本文系本站原创,欢迎转载! 转载请注明出处:http://ericxiao.cublog.cn/ -------- ...
- iOS开发——View的autoresizingMask属性
View的自适应属性autoresizingMask属性 每一个UIView都有一个autoresizingMask属性,这个属性是用于适应父视图的大小与子视图适应的,源码如下 enum { UIVi ...
- Storm系列(二)系统结构及重要概念
在Storm的集群里面有两种节点:控制节点和工作节点,控制节点上面运行Nimbus进程,Nimbus负责在集群里面分配计算任务,并且监控状态.每一个工作节点上面运行Supervisor进程,Super ...
- 【Mysql学习笔记】浅析mysql的binlog
最近读一份关于“数据库事务故障恢复"的技术资料,发现对mysql的binlog的认识不够清楚,查阅mysql reference manual有所收获,作为笔记,记录于此. 1. What' ...
- java中服务器启动时,执行定时任务
package com.ripsoft.util; import java.util.Calendar; import java.util.Timer; import javax.servlet.Se ...