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

01 <servlet>
02         <servlet-name>request_token</servlet-name>
03         <servlet-class>net.oauth.provider.servlets.RequestTokenServlet</servlet-class>
04     </servlet>
05     <servlet-mapping>
06         <servlet-name>request_token</servlet-name>
07         <url-pattern>/oauth/request_token</url-pattern>
08     </servlet-mapping>
09  
10     <servlet>
11         <servlet-name>access_token</servlet-name>
12         <servlet-class>net.oauth.provider.servlets.AccessTokenServlet</servlet-class>
13     </servlet>
14     <servlet-mapping>
15         <servlet-name>access_token</servlet-name>
16         <url-pattern>/oauth/access_token</url-pattern>
17     </servlet-mapping>
18  
19     <servlet>
20         <servlet-name>authorize</servlet-name>
21         <servlet-class>net.oauth.provider.servlets.AuthorizationServlet</servlet-class>
22     </servlet>
23     <servlet-mapping>
24         <servlet-name>authorize</servlet-name>
25         <url-pattern>/oauth/authorize</url-pattern>
26     </servlet-mapping>

5、做个拦截器,只要通过某url访问的都需要进行Oauth认证:

web.xml

1 <filter>
2        <filter-name>OauthFilter</filter-name>
3        <filter-class>web.school.phone.OauthFilter</filter-class>
4     </filter>
5     <filter-mapping>
6        <filter-name>OauthFilter</filter-name>
7        <url-pattern>/phone/*</url-pattern>
8     </filter-mapping>

web.school.phone.OauthFilter

01     package web.school.phone;
02          import java.io.IOException;
03  
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;
12  
13     import net.oauth.OAuthAccessor;
14     import net.oauth.OAuthMessage;
15     import net.oauth.provider.core.SampleOAuthProvider;
16     import net.oauth.server.OAuthServlet;
17  
18     public class OauthFilter implements Filter
{
19  
20       public void destroy()
{
21       }
22  
23       public void init(FilterConfig
fConfig) 
throws ServletException
{
24       }
25  
26       public void doFilter(ServletRequest
request, ServletResponse response, FilterChain chain)
27       throws IOException,
ServletException {
28         HttpServletRequest
req=(HttpServletRequest)request;
29         HttpServletResponse
res=(HttpServletResponse)response;
30  
31         try{
32             OAuthMessage
requestMessage = OAuthServlet.getMessage(req, 
null);
33             OAuthAccessor
accessor = SampleOAuthProvider.getAccessor(requestMessage);
34             SampleOAuthProvider.VALIDATOR.validateMessage(requestMessage,
accessor);
35  
36             System.out.println("[OauthFilter:passed]:"+req.getRequestURI());
37             chain.doFilter(request,
response);
//验证通过则转向
38  
39         catch (Exception
e){
40             //验证不通过
41             SampleOAuthProvider.handleException(e,
req, res, 
false);
42         }
43  
44       }
45  
46 }

6、执行客户端代码,提示输入验证码时,把控制台打印的URL放到浏览器里打开,输入授权码:

(服务端AuthorizationServlet 里面修改验证不通过要跳转的页面,页面上会打印一些参数)

JAVA Oauth 认证服务器的搭建的更多相关文章

  1. 一步一步搭建 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% ...

  2. 家用环境下部署wifidog认证服务器(java版)

    本文所讲的是基于一个java版wifidog认证服务器的开源项目,在windows环境下搭建wifidog认证服务器配合apfree固件实现用户名密码的认证. 大致步骤如下: 一,准备 1.搭建硬件及 ...

  3. oauth2使用心得-----基本概念以及认证服务器搭建

    应用场景 我们假设你有一个“云笔记”产品,并提供了“云笔记服务”和“云相册服务”,此时用户需要在不同的设备(PC.Android.iPhone.TV.Watch)上去访问这些“资源”(笔记,图片) 那 ...

  4. 拿nodejs快速搭建简单Oauth认证和restful API server攻略

    拿nodejs快速搭建简单Oauth认证和restful API server攻略:http://blog.csdn.net/zhaoweitco/article/details/21708955 最 ...

  5. authpuppy 认证服务器搭建

    此文仅限于搭建authpuppy认证服务器,不包含认证插件等安装,仅说明步骤以备下次安装忘记步骤.耽误时间. 环境:ubuntu10.04 软件版本:authpuppy-1.0.0-stable.tg ...

  6. Spring cloud微服务安全实战-4-5搭建OAuth2认证服务器

    现在可以访问我们的认证服务器,应用我们已经配置好了. 下面配置让用户可以访问我的认证服务器.再来重写一个方法. EndpointConfigure端点的配置. authenticationManage ...

  7. 阶段5 3.微服务项目【学成在线】_day16 Spring Security Oauth2_05-SpringSecurityOauth2研究-搭建认证服务器

    3 Spring Security Oauth2研究 3.1 目标 本项目认证服务基于Spring Security Oauth2进行构建,并在其基础上作了一些扩展,采用JWT令牌机制,并自定 义了用 ...

  8. 学习Spring Security OAuth认证(一)-授权码模式

    一.环境 spring boot+spring security+idea+maven+mybatis 主要是spring security 二.依赖 <dependency> <g ...

  9. OAuth认证协议原理分析及同步消息到Twitter和Facebook使用方法

    OAuth有什么用?为什么要使用OAuth? twitter或豆瓣用户一定会发现,有时候,在别的网站,点登录后转到 twitter登录,之后转回原网站,你会发现你已经登录此网站了,这种网站就是这个效果 ...

随机推荐

  1. 【转】linux /usr/bin/ld cannot find 解决

    原文网址:http://blog.csdn.net/mzwang123/article/details/6702889 问题:在linux环境编译应用程式或lib的source code时常常会出现如 ...

  2. 可视化zookeeper的事务日志(转)

    前面提到,在zookeeper server的配置文件zoo.cfg中可以通过dataLogDir来配置zookeeper的事务日志的输出目录,这个事务日志类似于下面这样的文件: 这个文件是一个二进制 ...

  3. Bootstrap之表格checkbox复选框全选 [转]

    转自: http://blog.csdn.net/shangmingchao/article/details/49761315 效果图: HTML中无需添加额外的一列来表示复选框,而是由JS完成,所以 ...

  4. 编译 skia

    0.准备工作 在 https://android.googlesource.com/ 用 git 代码,当然也可以从skia的官方https://code.google.com/p/skia/ 中获取 ...

  5. 单调栈 二 nyOj 最大矩形和

    主要思想来自 http://blog.csdn.net/wuyanyi/article/details/7243580 题目的连接,头次提交的同学需要注册 http://acm.nyist.net/J ...

  6. input子系统分析

    ------------------------------------------ 本文系本站原创,欢迎转载! 转载请注明出处:http://ericxiao.cublog.cn/ -------- ...

  7. iOS开发——View的autoresizingMask属性

    View的自适应属性autoresizingMask属性 每一个UIView都有一个autoresizingMask属性,这个属性是用于适应父视图的大小与子视图适应的,源码如下 enum { UIVi ...

  8. Storm系列(二)系统结构及重要概念

    在Storm的集群里面有两种节点:控制节点和工作节点,控制节点上面运行Nimbus进程,Nimbus负责在集群里面分配计算任务,并且监控状态.每一个工作节点上面运行Supervisor进程,Super ...

  9. 【Mysql学习笔记】浅析mysql的binlog

    最近读一份关于“数据库事务故障恢复"的技术资料,发现对mysql的binlog的认识不够清楚,查阅mysql reference manual有所收获,作为笔记,记录于此. 1. What' ...

  10. java中服务器启动时,执行定时任务

    package com.ripsoft.util; import java.util.Calendar; import java.util.Timer; import javax.servlet.Se ...