Browse Source

提交开源任务材料

10.0
LAPTOP-SB56SG4Q\86185 4 years ago
parent
commit
459e6cf235
  1. BIN
      JSD-7814 -需求确认书V1.docx
  2. 5
      README.md
  3. BIN
      jsd-7814配置使用文档.docx
  4. BIN
      lib/JWT-SDK-1.1.1_1.8.jar
  5. BIN
      lib/finekit-10.0.jar
  6. BIN
      lib/jose4j-0.7.3.jar
  7. 25
      plugin.xml
  8. 34
      src/main/java/com/fr/plugin/j7814/LifeCycleMonitorImpl.java
  9. 37
      src/main/java/com/fr/plugin/j7814/LocaleFinder.java
  10. 78
      src/main/java/com/fr/plugin/j7814/config/SsoConfig.java
  11. 151
      src/main/java/com/fr/plugin/j7814/request/GlobalRequestFilterBridge.java
  12. 90
      src/main/java/com/fr/plugin/j7814/request/HttpAuthorizeBridge.java
  13. 10
      src/main/resources/com/fr/plugin/j7814/sso/locale/lang.properties
  14. 10
      src/main/resources/com/fr/plugin/j7814/sso/locale/lang_zh_CN.properties

BIN
JSD-7814 -需求确认书V1.docx

Binary file not shown.

5
README.md

@ -1,3 +1,6 @@
# open-JSD-7814
JSD-7814 开源任务材料
jsd-7814 开源材料\
免责说明:该源码为第三方爱好者提供,不保证源码和方案的可靠性,也不提供任何形式的源码教学指导和协助!\
仅作为开发者学习参考使用!禁止用于任何商业用途!\
为保护开发者隐私,开发者信息已隐去!若原开发者希望公开自己的信息,可联系hugh处理。

BIN
jsd-7814配置使用文档.docx

Binary file not shown.

BIN
lib/JWT-SDK-1.1.1_1.8.jar

Binary file not shown.

BIN
lib/finekit-10.0.jar

Binary file not shown.

BIN
lib/jose4j-0.7.3.jar

Binary file not shown.

25
plugin.xml

@ -0,0 +1,25 @@
<?xml version="1.0" encoding="UTF-8"?>
<plugin>
<id>com.fr.plugin.j7814.sso</id>
<name><![CDATA[jsd7814-单点登陆]]></name>
<active>yes</active>
<version>1.1</version>
<env-version>10.0</env-version>
<jartime>2018-07-31</jartime>
<vendor>mqh</vendor>
<description><![CDATA[单点登陆jsd7814]]></description>
<change-notes><![CDATA[单点登陆jsd7814]]></change-notes>
<main-package>com.fr.plugin.j7814</main-package>
<prefer-packages>
<prefer-package>com.fanruan.api</prefer-package>
</prefer-packages>
<lifecycle-monitor class="com.fr.plugin.j7814.LifeCycleMonitorImpl"/>
<extra-core>
<LocaleFinder class="com.fr.plugin.j7814.LocaleFinder"/>
</extra-core>
<extra-decision>
<GlobalRequestFilterProvider class="com.fr.plugin.j7814.request.GlobalRequestFilterBridge"/>
<HttpAuthorizeProvider class="com.fr.plugin.j7814.request.HttpAuthorizeBridge"/>
</extra-decision>
<function-recorder class="com.fr.plugin.j7814.LocaleFinder"/>
</plugin>

34
src/main/java/com/fr/plugin/j7814/LifeCycleMonitorImpl.java

@ -0,0 +1,34 @@
/*
* Copyright (C), 2018-2021
* Project: starter
* FileName: OneAccessLifeCycleMonitor
* Author: Louis
* Date: 2021/3/30 15:10
*/
package com.fr.plugin.j7814;
import com.fr.plugin.context.PluginContext;
import com.fr.plugin.observer.inner.AbstractPluginLifecycleMonitor;
import com.fr.plugin.j7814.config.SsoConfig;
/**
* <Function Description><br>
* <OneAccessLifeCycleMonitor>
*
* @author Louis
* @since 1.0.0
*/
public class LifeCycleMonitorImpl extends AbstractPluginLifecycleMonitor {
public LifeCycleMonitorImpl() {
}
@Override
public void afterRun(PluginContext pluginContext) {
SsoConfig.getInstance();
}
@Override
public void beforeStop(PluginContext pluginContext) {
}
}

37
src/main/java/com/fr/plugin/j7814/LocaleFinder.java

@ -0,0 +1,37 @@
/*
* Copyright (C), 2018-2020
* Project: starter
* FileName: LocaleFinder
* Author: Louis
* Date: 2020/8/31 22:19
*/
package com.fr.plugin.j7814;
import com.fr.intelli.record.Focus;
import com.fr.intelli.record.Original;
import com.fr.record.analyzer.EnableMetrics;
import com.fr.stable.fun.impl.AbstractLocaleFinder;
import static com.fr.plugin.j7814.config.SsoConfig.PLUGIN_ID;
/**
* <Function Description><br>
* <LocaleFinder>
*
* @author Louis
* @since 1.0.0
*/
@EnableMetrics
public class LocaleFinder extends AbstractLocaleFinder {
@Override
@Focus(id = PLUGIN_ID, text = "Plugin-J7814-Sso", source = Original.PLUGIN)
public String find() {
return "com/fr/plugin/j7814/sso/locale/lang";
}
@Override
public int currentAPILevel() {
return CURRENT_LEVEL;
}
}

78
src/main/java/com/fr/plugin/j7814/config/SsoConfig.java

@ -0,0 +1,78 @@
/*
* Copyright (C), 2018-2021
* Project: starter
* FileName: OneAccessConfig
* Author: Louis
* Date: 2021/3/30 9:38
*/
package com.fr.plugin.j7814.config;
import com.fanruan.api.util.StringKit;
import com.fr.config.*;
import com.fr.config.holder.Conf;
import com.fr.config.holder.factory.Holders;
import com.fr.intelli.record.Focus;
import com.fr.intelli.record.Original;
/**
* <Function Description><br>
* <SsoConfig>
*
* @author Louis
* @since 1.0.0
*/
@Visualization(category = "Plugin-J7814-Sso_Group")
public class SsoConfig extends DefaultConfiguration {
public static final String PLUGIN_ID = "com.fr.plugin.j7814";
private static volatile SsoConfig config = null;
@Focus(id = PLUGIN_ID, text = "Plugin-J7814-Sso", source = Original.PLUGIN)
public static SsoConfig getInstance() {
if (config == null) {
config = ConfigContext.getConfigInstance(SsoConfig.class);
}
return config;
}
@Identifier(value = "clientId", name = "Plugin-J7814-Sso_Config_clientId", description = "Plugin-J7814-Sso_Config_clientId_Description", status = Status.SHOW)
private Conf<String> clientId = Holders.simple(StringKit.EMPTY);
@Identifier(value = "clientSecret", name = "Plugin-J7814-Sso_Config_clientSecret", description = "Plugin-J7814-Sso_Config_clientSecret_Description", status = Status.SHOW)
private Conf<String> clientSecret = Holders.simple(StringKit.EMPTY);
@Identifier(value = "ipgUrl", name = "Plugin-J7814-Sso_Config_ipgUrl", description = "Plugin-J7814-Sso_Config_ipgUrl_Description", status = Status.SHOW)
private Conf<String> ipgUrl = Holders.simple(StringKit.EMPTY);
@Identifier(value = "publicKey", name = "Plugin-J7814-Sso_Config_publicKey", description = "Plugin-J7814-Sso_Config_publicKey_Description", status = Status.SHOW)
private Conf<String> publicKey = Holders.simple(StringKit.EMPTY);
public String getClientId() {
return clientId.get();
}
public void setClientId(String clientId) {
this.clientId.set(clientId);
}
public String getClientSecret() {
return clientSecret.get();
}
public void setClientSecret(String clientSecret) {
this.clientSecret.set(clientSecret);
}
public String getIpgUrl() {
return ipgUrl.get();
}
public void setIpgUrl(String ipgUrl) {
this.ipgUrl.set(ipgUrl);
}
public String getPublicKey() {
return publicKey.get();
}
public void setPublicKey(String publicKey) {
this.publicKey.set(publicKey);
}
}

151
src/main/java/com/fr/plugin/j7814/request/GlobalRequestFilterBridge.java

@ -0,0 +1,151 @@
/*
* Copyright (C), 2018-2021
* Project: starter
* FileName: GlobalRequestFilterBridge
* Author: Louis
* Date: 2021/3/30 22:09
*/
package com.fr.plugin.j7814.request;
import com.fanruan.api.decision.login.LoginKit;
import com.fanruan.api.log.LogKit;
import com.fanruan.api.net.NetworkKit;
import com.fanruan.api.util.StringKit;
import com.fr.decision.fun.impl.AbstractGlobalRequestFilterProvider;
import com.fr.decision.webservice.utils.DecisionServiceConstants;
import com.fr.decision.webservice.v10.login.LoginService;
import com.fr.plugin.j7814.config.SsoConfig;
import com.idsmanager.dingdang.jwt.DingdangUserRetriever;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* <Function Description><br>
* <GlobalRequestFilterBridge>
*
* @author Louis
* @since 1.0.0
*/
public class GlobalRequestFilterBridge extends AbstractGlobalRequestFilterProvider {
public static final String REMOTE_DESIGN = "/remote/design";
public static final String RESOURCES_PATH = "/resources";
public static final String VIEW_FORM = "/view/form";
public static final String VIEW_REPORT = "/view/report";
public static final String FILE_PATH = "/file";
public static final String SYSTEM_INFO = "/system/info";
public static final String MATERIALS_MIN_JS_MAP = "/materials.min.js.map";
public static final String LOGIN_PATH = "/login";
public static final String LOGIN_OTHER = "/login/";
public static final String LOGOUT_PATH = "/logout";
public static final String USER_LANGUAGE = "/v10/user/language";
public static final String ID_TOKEN = "id_token";
private SsoConfig config;
/**
* 过滤器名称
*
* @return
*/
@Override
public String filterName() {
return "J7814Filter";
}
/**
* 过滤规则
*
* @return
*/
@Override
public String[] urlPatterns() {
return new String[]{"/decision/*"};
}
/**
* 过滤器初始化
*
* @param filterConfig
*/
@Override
public void init(FilterConfig filterConfig) {
this.config = SsoConfig.getInstance();
super.init(filterConfig);
}
/**
* 过滤器处理
*
* @param request
* @param response
* @param filterChain
*/
@Override
public void doFilter(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) {
try {
if (operation(request, response)) {
filterChain.doFilter(request, response);
}
} catch (Exception e) {
LogKit.error(e.getMessage(), e);
}
}
/**
* 用户验证登陆操作
*
* @param req
* @param res
* @throws Exception
*/
private boolean operation(HttpServletRequest req, HttpServletResponse res) throws Exception {
String pathInfo = (req.getPathInfo() != null) ? req.getPathInfo() : StringKit.EMPTY;
LogKit.error("sso-GlobalRequestFilterBridge-operation-pathInfo:{}", pathInfo);
if (pathInfo.startsWith(REMOTE_DESIGN) || pathInfo.startsWith(LOGIN_OTHER)
|| StringKit.equals(LOGIN_PATH, pathInfo)
|| pathInfo.startsWith(RESOURCES_PATH) || pathInfo.startsWith(LOGOUT_PATH)
|| pathInfo.startsWith(SYSTEM_INFO) || pathInfo.startsWith(MATERIALS_MIN_JS_MAP)
|| pathInfo.startsWith(USER_LANGUAGE) || pathInfo.startsWith(FILE_PATH)) {
return true;
}
// if (pathInfo.startsWith(VIEW_REPORT) || pathInfo.startsWith(VIEW_FORM)) {
// return true;
// }
// 已登录
if (LoginService.getInstance().isLogged(req)) {
return true;
}
String token = NetworkKit.getHTTPRequestParameter(req, ID_TOKEN);
LogKit.error("sso-GlobalRequestFilterBridge-operation-token:{}", token);
if (StringKit.isEmpty(token)) {
return true;
}
String username = getUsername(token);
LogKit.error("sso-GlobalRequestFilterBridge-operation-username:{}", username);
if (StringKit.isEmpty(username)) {
return true;
}
String tokenFR = LoginKit.login(req, res, username);
req.setAttribute(DecisionServiceConstants.FINE_AUTH_TOKEN_NAME, tokenFR);
return true;
}
/**
* 通过凭证获得username
*
* @param token
* @return
*/
private String getUsername(String token) throws Exception {
DingdangUserRetriever retriever = new DingdangUserRetriever(token, this.config.getPublicKey());
DingdangUserRetriever.User user = retriever.retrieve();
if (user == null) {
return StringKit.EMPTY;
}
return user.getUsername();
}
}

90
src/main/java/com/fr/plugin/j7814/request/HttpAuthorizeBridge.java

@ -0,0 +1,90 @@
/**
* Copyright (C), 2015-2019
* FileName: HttpAuthorizeBridge
* Author: Louis
* Date: 2019/8/9 9:24
* Description: HttpAuthorizeBridge
* History:
* <author> <time> <version> <desc>
*/
package com.fr.plugin.j7814.request;
import com.fanruan.api.json.JSONKit;
import com.fanruan.api.log.LogKit;
import com.fanruan.api.net.http.HttpKit;
import com.fanruan.api.util.StringKit;
import com.fr.decision.fun.impl.AbstractHttpAuthorizeProvider;
import com.fr.general.ComparatorUtils;
import com.fr.json.JSONArray;
import com.fr.json.JSONObject;
import com.fr.plugin.j7814.config.SsoConfig;
import com.fr.third.org.apache.http.entity.StringEntity;
import java.util.HashMap;
import java.util.Map;
/**
* Function Description<br>
* HttpAuthorizeBridge http认证
*
* @author Louis
* @since 1.0.0
*/
public class HttpAuthorizeBridge extends AbstractHttpAuthorizeProvider {
@Override
public Scope scope() {
return Scope.REPLACE;
}
@Override
public boolean authorize(String inputUsername, String inputPassword, String savedPassword, String hashPassword) {
SsoConfig config = SsoConfig.getInstance();
String httpUrl = config.getIpgUrl();
if (StringKit.isEmpty(httpUrl)) {
return false;
}
try {
JSONObject bodyParams = JSONKit.create();
bodyParams.put("username", inputUsername);
bodyParams.put("password", inputPassword);
bodyParams.put("clientId", config.getClientId());
bodyParams.put("clientSecret", config.getClientSecret());
Map<String, String> headers = new HashMap<>();
headers.put("Content-Type", "application/json");
StringEntity stringEntity = new StringEntity(bodyParams.encode(), "UTF-8");
String result = HttpKit.executeAndParse(com.fanruan.api.net.http.rs.HttpRequest.custom()
.url(httpUrl).post(stringEntity).headers(headers).build());
LogKit.error("sso-HttpAuthorizeBridge-authorize-result:{}", result);
return validateResult(result, inputUsername);
} catch (Exception e) {
LogKit.error(e.getMessage(), e);
}
return false;
}
/**
* 判断验证结果
*
* @param result
* @param inputUsername
* @return
*/
private Boolean validateResult(String result, String inputUsername){
if (StringKit.isEmpty(result)){
return false;
}
final JSONObject jsonObject = JSONKit.create(result);
int errorNumber = jsonObject.getInt("errorNumber");
if (!ComparatorUtils.equals(errorNumber, 0)) {
return false;
}
final JSONObject applicationObject = jsonObject.getJSONObject("applicationAPIDto");
JSONArray applicationUsername = applicationObject.getJSONArray("applicationUsernames");
if (applicationUsername == null || applicationUsername.isEmpty()) {
LogKit.error("sso-HttpAuthorizeBridge-validateResult-applicationUsername is null.");
return false;
}
return applicationUsername.contains(inputUsername);
}
}

10
src/main/resources/com/fr/plugin/j7814/sso/locale/lang.properties

@ -0,0 +1,10 @@
Plugin-J7814-Sso=Sso Plugin
Plugin-J7814-Sso_Group=Sso Plugin
Plugin-J7814-Sso_Config_clientId=ClientId
Plugin-J7814-Sso_Config_clientId_Description=ClientId
Plugin-J7814-Sso_Config_clientSecret=ClientSecret
Plugin-J7814-Sso_Config_clientSecret_Description=ClientSecret
Plugin-J7814-Sso_Config_ipgUrl=IPG Url
Plugin-J7814-Sso_Config_ipgUrl_Description=IPG Url
Plugin-J7814-Sso_Config_publicKey=Public Key
Plugin-J7814-Sso_Config_publicKey_Description=Public Key

10
src/main/resources/com/fr/plugin/j7814/sso/locale/lang_zh_CN.properties

@ -0,0 +1,10 @@
Plugin-J7814-Sso=\u5355\u70B9\u767B\u9646\u63D2\u4EF6
Plugin-J7814-Sso_Group=\u5355\u70B9\u767B\u9646\u63D2\u4EF6
Plugin-J7814-Sso_Config_clientId=ClientId
Plugin-J7814-Sso_Config_clientId_Description=ClientId
Plugin-J7814-Sso_Config_clientSecret=ClientSecret
Plugin-J7814-Sso_Config_clientSecret_Description=ClientSecret
Plugin-J7814-Sso_Config_ipgUrl=IPG Url
Plugin-J7814-Sso_Config_ipgUrl_Description=IPG Url
Plugin-J7814-Sso_Config_publicKey=\u516C\u94A5
Plugin-J7814-Sso_Config_publicKey_Description=\u516C\u94A5
Loading…
Cancel
Save