1d6817c1d8c334131f0c1cdf6f6c480666e672ff.svn-base 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287
  1. <template>
  2. <a-modal
  3. :title="title"
  4. :width="800"
  5. :visible="visible"
  6. :confirmLoading="confirmLoading"
  7. @ok="handleOk"
  8. @cancel="handleCancel"
  9. cancelText="关闭">
  10. <a-spin :spinning="confirmLoading">
  11. <a-form :form="form">
  12. <a-form-item
  13. :labelCol="labelCol"
  14. :wrapperCol="wrapperCol"
  15. label="数据源编码">
  16. <a-input placeholder="请输入数据源编码" :disabled="!!model.id" v-decorator="['code', validatorRules.code]"/>
  17. </a-form-item>
  18. <a-form-item
  19. :labelCol="labelCol"
  20. :wrapperCol="wrapperCol"
  21. label="数据源名称">
  22. <a-input placeholder="请输入数据源名称" v-decorator="['name', validatorRules.name]"/>
  23. </a-form-item>
  24. <a-form-item
  25. :labelCol="labelCol"
  26. :wrapperCol="wrapperCol"
  27. label="数据库类型">
  28. <j-dict-select-tag placeholder="请选择数据库类型" dict-code="database_type" triggerChange v-decorator="['dbType', validatorRules.dbType]" @change="handleDbTypeChange"/>
  29. </a-form-item>
  30. <a-form-item
  31. :labelCol="labelCol"
  32. :wrapperCol="wrapperCol"
  33. label="驱动类">
  34. <a-input placeholder="请输入驱动类" v-decorator="['dbDriver', validatorRules.dbDriver]"/>
  35. </a-form-item>
  36. <a-form-item
  37. :labelCol="labelCol"
  38. :wrapperCol="wrapperCol"
  39. label="数据源地址">
  40. <a-input placeholder="请输入数据源地址" v-decorator="['dbUrl', validatorRules.dbUrl]"/>
  41. </a-form-item>
  42. <!-- <a-form-item
  43. :labelCol="labelCol"
  44. :wrapperCol="wrapperCol"
  45. label="数据库名称">
  46. <a-input placeholder="请输入数据库名称" v-decorator="['dbName', validatorRules.dbName]"/>
  47. </a-form-item>-->
  48. <a-form-item
  49. :labelCol="labelCol"
  50. :wrapperCol="wrapperCol"
  51. label="用户名">
  52. <a-input placeholder="请输入用户名" v-decorator="['dbUsername', validatorRules.dbUsername]"/>
  53. </a-form-item>
  54. <a-form-item
  55. :labelCol="labelCol"
  56. :wrapperCol="wrapperCol"
  57. label="密码">
  58. <a-row :gutter="8">
  59. <a-col :span="21">
  60. <a-input-password placeholder="请输入密码" v-decorator="['dbPassword', validatorRules.dbPassword]"/>
  61. </a-col>
  62. <a-col :span="3">
  63. <a-button type="primary" size="small" style="width: 100%" @click="handleTest">测试</a-button>
  64. </a-col>
  65. </a-row>
  66. </a-form-item>
  67. <a-form-item
  68. :labelCol="labelCol"
  69. :wrapperCol="wrapperCol"
  70. label="备注">
  71. <a-textarea placeholder="请输入备注" v-decorator="['remark', {}]"/>
  72. </a-form-item>
  73. </a-form>
  74. </a-spin>
  75. </a-modal>
  76. </template>
  77. <script>
  78. import pick from 'lodash.pick'
  79. import { httpAction, postAction } from '@/api/manage'
  80. import { validateDuplicateValue } from '@/utils/util'
  81. export default {
  82. name: 'SysDataSourceModal',
  83. components: {},
  84. data() {
  85. return {
  86. title: '操作',
  87. visible: false,
  88. model: {},
  89. labelCol: {
  90. xs: { span: 24 },
  91. sm: { span: 5 },
  92. },
  93. wrapperCol: {
  94. xs: { span: 24 },
  95. sm: { span: 16 },
  96. },
  97. confirmLoading: false,
  98. form: this.$form.createForm(this),
  99. validatorRules: {
  100. code: {
  101. validateFirst: true,
  102. rules: [
  103. { required: true, message: '请输入数据源编码!' },
  104. {
  105. validator: (rule, value, callback) => {
  106. let pattern = /^[a-z|A-Z][a-z|A-Z\d_-]{0,}$/
  107. if (!pattern.test(value)) {
  108. callback('编码必须以字母开头,可包含数字、下划线、横杠')
  109. } else {
  110. validateDuplicateValue('sys_data_source', 'code', value, this.model.id, callback)
  111. }
  112. }
  113. }
  114. ]
  115. },
  116. name: { rules: [{ required: true, message: '请输入数据源名称!' }] },
  117. dbType: { rules: [{ required: true, message: '请选择数据库类型!' }] },
  118. dbDriver: { rules: [{ required: true, message: '请输入驱动类!' }] },
  119. dbUrl: { rules: [{ required: true, message: '请输入数据源地址!' }] },
  120. dbName: { rules: [{ required: true, message: '请输入数据库名称!' }] },
  121. dbUsername: { rules: [{ required: true, message: '请输入用户名!' }] },
  122. dbPassword: { rules: [{ required: false, message: '请输入密码!' }] }
  123. },
  124. url: {
  125. add: '/sys/dataSource/add',
  126. edit: '/sys/dataSource/edit',
  127. },
  128. dbDriverMap: {
  129. // MySQL 数据库
  130. '1': { dbDriver: 'com.mysql.jdbc.Driver' },
  131. //MySQL5.7+ 数据库
  132. '4': { dbDriver: 'com.mysql.cj.jdbc.Driver' },
  133. // Oracle
  134. '2': { dbDriver: 'oracle.jdbc.OracleDriver' },
  135. // SQLServer 数据库
  136. '3': { dbDriver: 'com.microsoft.sqlserver.jdbc.SQLServerDriver' },
  137. // marialDB 数据库
  138. '5': { dbDriver: 'org.mariadb.jdbc.Driver' },
  139. // postgresql 数据库
  140. '6': { dbDriver: 'org.postgresql.Driver' },
  141. // 达梦 数据库
  142. '7': { dbDriver: 'dm.jdbc.driver.DmDriver' },
  143. // 人大金仓 数据库
  144. '8': { dbDriver: 'com.kingbase8.Driver' },
  145. // 神通 数据库
  146. '9': { dbDriver: 'com.oscar.Driver' },
  147. // SQLite 数据库
  148. '10': { dbDriver: 'org.sqlite.JDBC' },
  149. // DB2 数据库
  150. '11': { dbDriver: 'com.ibm.db2.jcc.DB2Driver' },
  151. // Hsqldb 数据库
  152. '12': { dbDriver: 'org.hsqldb.jdbc.JDBCDriver' },
  153. // Derby 数据库
  154. '13': { dbDriver: 'org.apache.derby.jdbc.ClientDriver' },
  155. // H2 数据库
  156. '14': { dbDriver: 'org.h2.Driver' },
  157. // 其他数据库
  158. '15': { dbDriver: '' }
  159. },
  160. dbUrlMap: {
  161. // MySQL 数据库
  162. '1': { dbUrl: 'jdbc:mysql://127.0.0.1:3306/jeecg-boot?characterEncoding=UTF-8&useUnicode=true&useSSL=false' },
  163. //MySQL5.7+ 数据库
  164. '4': { dbUrl: 'jdbc:mysql://127.0.0.1:3306/jeecg-boot?characterEncoding=UTF-8&useUnicode=true&useSSL=false&tinyInt1isBit=false&allowPublicKeyRetrieval=true&serverTimezone=Asia/Shanghai' },
  165. // Oracle
  166. '2': { dbUrl: 'jdbc:oracle:thin:@127.0.0.1:1521:ORCL' },
  167. // SQLServer 数据库
  168. '3': { dbUrl: 'jdbc:sqlserver://127.0.0.1:1433;SelectMethod=cursor;DatabaseName=jeecgboot' },
  169. // Mariadb 数据库
  170. '5': { dbUrl: 'jdbc:mariadb://127.0.0.1:3306/jeecg-boot?characterEncoding=UTF-8&useSSL=false' },
  171. // Postgresql 数据库
  172. '6': { dbUrl: 'jdbc:postgresql://127.0.0.1:5432/jeecg-boot' },
  173. // 达梦 数据库
  174. '7': { dbUrl: 'jdbc:dm://127.0.0.1:5236/?jeecg-boot&zeroDateTimeBehavior=convertToNull&useUnicode=true&characterEncoding=utf-8' },
  175. // 人大金仓 数据库
  176. '8': { dbUrl: 'jdbc:kingbase8://127.0.0.1:54321/jeecg-boot' },
  177. // 神通 数据库
  178. '9': { dbUrl: 'jdbc:oscar://192.168.1.125:2003/jeecg-boot' },
  179. // SQLite 数据库
  180. '10': { dbUrl: 'jdbc:sqlite://opt/test.db' },
  181. // DB2 数据库
  182. '11': { dbUrl: 'jdbc:db2://127.0.0.1:50000/jeecg-boot' },
  183. // Hsqldb 数据库
  184. '12': { dbUrl: 'jdbc:hsqldb:hsql://127.0.0.1/jeecg-boot' },
  185. // Derby 数据库
  186. '13': { dbUrl: 'jdbc:derby://127.0.0.1:1527/jeecg-boot' },
  187. // H2 数据库
  188. '14': { dbUrl: 'jdbc:h2:tcp://127.0.0.1:8082/jeecg-boot' },
  189. // 其他数据库
  190. '15': { dbUrl: '' }
  191. }
  192. }
  193. },
  194. created() {
  195. },
  196. methods: {
  197. add() {
  198. this.edit({})
  199. },
  200. edit(record) {
  201. this.form.resetFields()
  202. this.model = Object.assign({}, record)
  203. this.visible = true
  204. this.$nextTick(() => {
  205. this.form.setFieldsValue(pick(this.model, 'code', 'name', 'remark', 'dbType', 'dbDriver', 'dbUrl', 'dbName', 'dbUsername', 'dbPassword'))
  206. })
  207. },
  208. close() {
  209. this.$emit('close')
  210. this.visible = false
  211. },
  212. handleOk() {
  213. // 触发表单验证
  214. this.form.validateFields((err, values) => {
  215. if (!err) {
  216. this.confirmLoading = true
  217. let formData = Object.assign(this.model, values)
  218. let httpUrl = this.url.add, method = 'post'
  219. if (this.model.id) {
  220. httpUrl = this.url.edit
  221. //method = 'put'
  222. // 由于编码的特殊性,所以不能更改
  223. formData['code'] = undefined
  224. }
  225. httpAction(httpUrl, formData, method).then((res) => {
  226. if (res.success) {
  227. this.$message.success(res.message)
  228. this.$emit('ok')
  229. this.close()
  230. } else {
  231. this.$message.warning(res.message)
  232. }
  233. }).finally(() => {
  234. this.confirmLoading = false
  235. })
  236. }
  237. })
  238. },
  239. handleCancel() {
  240. this.close()
  241. },
  242. // 测试数据源配置是否可以正常连接
  243. handleTest() {
  244. let keys = ['dbType', 'dbDriver', 'dbUrl', 'dbName', 'dbUsername', 'dbPassword']
  245. // 获取以上字段的值,并清除校验状态
  246. let fieldsValues = this.form.getFieldsValue(keys)
  247. let setFields = {}
  248. keys.forEach(key => setFields[key] = { value: fieldsValues[key], errors: null })
  249. // 清除校验状态,目的是可以让错误文字闪烁
  250. this.form.setFields(setFields)
  251. // 重新校验
  252. this.$nextTick(() => {
  253. this.form.validateFields(keys, (errors, values) => {
  254. if (!errors) {
  255. let loading = this.$message.loading('连接中……', 0)
  256. postAction('/online/cgreport/api/testConnection', fieldsValues).then(res => {
  257. if (res.success) {
  258. this.$message.success('连接成功')
  259. } else throw new Error(res.message)
  260. }).catch(error => {
  261. this.$warning({ title: '连接失败', content: error.message || error })
  262. }).finally(() => loading())
  263. }
  264. })
  265. })
  266. },
  267. // 数据库类型更改时,联动更改数据库驱动
  268. handleDbTypeChange(val) {
  269. let dbDriver = this.dbDriverMap[val]
  270. let dbUrl = this.dbUrlMap[val]
  271. if (dbDriver) {
  272. this.form.setFieldsValue(dbDriver)
  273. }
  274. if (dbUrl) {
  275. this.form.setFieldsValue(dbUrl)
  276. }
  277. },
  278. }
  279. }
  280. </script>
  281. <style lang="less" scoped></style>