个人博客导航页(点击右侧链接即可打开个人博客):互联网老兵带你入门技术栈
使用Java程序发送Http请求进行o2server登录认证
o2server向外提供了非常完整的restful服务,用户可以使用任何语言,编写代码发起http请求来进行o2server功能和业务的操作。大多数服务的调用,都需要进行登录认证,本篇详细介绍如何使用其他语言来发送http请求进行服务器认证。
(1)发送用户名使用SSO进行登录认证
此示例演示如何通过登录用户名,和SSO相关的配置,使用单点认证的方式进行O2Server的登录认证,获取xtoken信息
涉及到加密解密,请使用非中文的唯一标识进行登录 ,中文登录 有可能会有找不到用户的问题。
一、o2Server平台SSO配置
1、使用管理员(或者xadmin)登录O2OA
2、打开系统菜单->控制面板->系统设置->SSO配置
打开控制面板
进入系统设置
进入SSO配置
3、添加SSO配置
添加一个SSO配置
4、重启o2server
二、编写登录代码
完整代码内容:O.java
package net.o2oa.demos; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.PrintWriter; import java.net.URL; import java.net.URLConnection; import java.util.Date; import org.apache.commons.codec.binary.StringUtils; import org.json.JSONObject; import net.o2oa.util.Crypto; /** * 此示例演示如何通过登录用户名,和SSO相关的配置,使用单点认证的方式进行O2Server的登录认证,获取xtoken信息 * 涉及到加密解密,请使用非中文的唯一标识进行登录 ,中文登录 有可能会有找不到用户的问题。 * @author O2OA */ public class Demo_LoginWithSSO { static final String URL_SSOLOGIN="/x_organization_assemble_authentication/jaxrs/sso"; public static void main( String[] args ) { String applicationServer = "127.0.0.1"; Integer applicationPort = 20020; String userName = "13533441287"; String ssoClient = "sso_demo"; String key = "sso123456"; try { LoginResult result = login(applicationServer, applicationPort, userName, ssoClient, key); if( StringUtils.equals( "success", result.getType() )) { System.out.println("xtoken=" + result.getToken() ); }else { System.out.println("message:" + result.getMessage() ); } } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } //服务地址:http://127.0.0.1:20020/x_organization_assemble_authentication/jaxrs/sso //{"token":"xadmin","client":"sso_demo"} /** * 使用登录认证的接口进行服务器登录,获取xtoken信息 * @param applicationServer 127.0.0.1 * @param applicationPort 20020 * @param userName 张三 * @param client sso_demo * @param key sso123456 * @return * @throws Exception */ public static LoginResult login( String applicationServer, Integer applicationPort, String userName, String client, String key ) throws Exception { //参数 String loginUrl = "http://" + applicationServer + ":" + applicationPort + URL_SSOLOGIN ; String xtoken = Crypto.encrypt( userName + "#" + new Date().getTime(), key ); String loginParams = String.format("{'token':'%s','client':'%s'}", xtoken, client ); String responseData = sendPost( loginUrl, loginParams );
/** * 成功响应结果 * { "type": "success", "data": { "token": "Xb9XTOjIQJa5AVRfHfIbNMFvhYdVfLgaipZBZBiUF7aNHeLrQ4vOu9YgprWeK2E1YsxApE_z4f1mvqvStFQI5CW7Pk31ulroUVAeR5jUybQ", "roleList": [], "id": "1cb47e12-18ad-4363-a55f-4514edb76215", "genderType": "m", "signature": "", "pinyin": "lisi", "pinyinInitial": "ls", "description": "", "name": "李四", "employee": "", "unique": "c93b7fb8-6820-466c-ab9c-f0637b8a3682", "distinguishedName": "李四@c93b7fb8-6820-466c-ab9c-f0637b8a3682@P", "orderNumber": 56649305, "controllerList": [], "superior": "", "changePasswordTime": "2019-10-18", "mail": "", "weixin": "", &