-
Notifications
You must be signed in to change notification settings - Fork 264
/
Copy pathDemoApplication.java
131 lines (112 loc) · 4.91 KB
/
DemoApplication.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
/*Copyright ©2016 TommyLemon(https://github.com/TommyLemon/APIJSON)
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.*/
package apijson.demo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.boot.web.server.WebServerFactoryCustomizer;
import org.springframework.boot.web.servlet.server.ConfigurableServletWebServerFactory;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import apijson.Log;
import apijson.demo.script.GraalJavaScriptExecutor;
import apijson.demo.script.LuaScriptExecutor;
import apijson.demo.script.NashornScriptExecutor;
import apijson.framework.javax.APIJSONApplication;
import apijson.framework.javax.APIJSONCreator;
import apijson.orm.SQLConfig;
import apijson.orm.SQLExecutor;
import apijson.orm.script.ScriptExecutor;
/**
* Demo SpringBoot Application 主应用程序启动类 右键这个类 > Run As > Java Application 具体见
* SpringBoot 文档
* https://www.springcloud.cc/spring-boot.html#using-boot-locating-the-main-class
*
* @author Lemon
*/
@Configuration
@SpringBootApplication
@EnableConfigurationProperties
public class DemoApplication implements WebServerFactoryCustomizer<ConfigurableServletWebServerFactory> {
// 全局 ApplicationContext 实例,方便 getBean 拿到 Spring/SpringBoot 注入的类实例
private static ApplicationContext APPLICATION_CONTEXT;
public static ApplicationContext getApplicationContext() {
return APPLICATION_CONTEXT;
}
public static void main(String[] args) throws Exception {
APPLICATION_CONTEXT = SpringApplication.run(DemoApplication.class, args);
Log.DEBUG = true;
// 加载扩展脚本执行器
extendScriptExecutor();
APIJSONApplication.init(false); // 4.4.0 以上需要这句来保证以上 static 代码块中给 DEFAULT_APIJSON_CREATOR 赋值会生效
}
public static void extendScriptExecutor() {
ScriptExecutor javaScriptExecutor = new NashornScriptExecutor();
ScriptExecutor luaExecutor = new LuaScriptExecutor();
ScriptExecutor GraalJSExecutor = new GraalJavaScriptExecutor();
APIJSONApplication.addScriptExecutor("nashornJS", javaScriptExecutor);
APIJSONApplication.addScriptExecutor("luaj", luaExecutor);
APIJSONApplication.addScriptExecutor("graalJS", GraalJSExecutor);
}
// SpringBoot 2.x 自定义端口方式
@Override
public void customize(ConfigurableServletWebServerFactory server) {
server.setPort(8080);
}
// 支持 APIAuto 中 JavaScript 代码跨域请求
@Bean
public WebMvcConfigurer corsConfigurer() {
return new WebMvcConfigurer() {
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/**").allowedOriginPatterns("*").allowedMethods("*").allowCredentials(true).maxAge(3600);
}
};
}
static {
// 使用本项目的自定义处理类
APIJSONApplication.DEFAULT_APIJSON_CREATOR = new APIJSONCreator<Long>() {
@Override
public SQLConfig createSQLConfig() {
return new DemoSQLConfig();
}
@Override
public SQLExecutor createSQLExecutor() {
return new DemoSQLExecutor();
}
};
// 把以下需要用到的数据库驱动取消注释即可,如果这里没有可以自己新增
// try { //加载驱动程序
// Log.d(TAG, "尝试加载 SQLServer 驱动 <<<<<<<<<<<<<<<<<<<<< ");
// Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
// Log.d(TAG, "成功加载 SQLServer 驱动!>>>>>>>>>>>>>>>>>>>>> ");
// }
// catch (ClassNotFoundException e) {
// e.printStackTrace();
// Log.e(TAG, "加载 SQLServer 驱动失败,请检查 pom.xml 中 net.sourceforge.jtds 版本是否存在以及可用
// !!!");
// }
//
// try { //加载驱动程序
// Log.d(TAG, "尝试加载 Oracle 驱动 <<<<<<<<<<<<<<<<<<<<< ");
// Class.forName("oracle.jdbc.driver.OracleDriver");
// Log.d(TAG, "成功加载 Oracle 驱动!>>>>>>>>>>>>>>>>>>>>> ");
// }
// catch (ClassNotFoundException e) {
// e.printStackTrace();
// Log.e(TAG, "加载 Oracle 驱动失败,请检查 pom.xml 中 com.oracle.jdbc 版本是否存在以及可用 !!!");
// }
}
}