प्रौद्योगिकी साझेदारी

vue3 springboot mybatis mysql परियोजना सरलप्रवेशस्य पञ्जीकरणकार्यस्य च अभ्यास-कार्यन्वयनम्

2024-07-12

한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina

अत्र vue3+springboot+mybatis+mysql इत्यस्य परियोजना कार्यान्वयनम् अस्ति, यत् केवलं अग्रे-अन्त-पृष्ठ-अन्त-पृथक्करणस्य प्रवेश-पञ्जीकरण-कार्यं कार्यान्वितं करोति मुख्यानि साधनानि सन्ति: विचारः, navicat

विषयवस्तुसारणी

1. vue3 परियोजनां प्रारम्भिकविन्यासं च रचयन्तु

vue3 परियोजना रचयन्तु

2. परियोजनासंरचनायाः परिवर्तनं कुर्वन्तु

१) मूलनिर्देशिकासंरचना

२) परिवर्तिता निर्देशिकासंरचना

प्रवेशपञ्जीकरणपृष्ठं सम्पादयित्वा लिखन्तु

1)LoginAndRegister.vue

२)गृहम् ।vue

३)रूटरः

४)प्रवेशः ।css

५) प्रवेशपञ्जीकरणपृष्ठप्रदर्शनम्

2. springboot+mysql+mybatis परियोजनां रचयन्तु तथा च आँकडाधारेण सह सम्बद्धं कुर्वन्तु

3. लॉगिन् तथा पञ्जीकरणपृष्ठ-अन्त-कार्यं लिखन्तु

1. प्रवेश तर्कः

2. पञ्जीकरणतर्कः

3. बैकएण्ड् कोड भाग

4. परियोजनां चालयन्तु


1. vue3 परियोजनां प्रारम्भिकविन्यासं च रचयन्तु

1. vue3 परियोजना रचयन्तु

परियोजनां निर्मातुं भवान् मम एकं लेखं द्रष्टुं शक्नोति:

IDEA_idea vue3-CSDN blog इत्यनेन सह कस्टम् vue3 परियोजनां रचयन्तु

निर्माणानन्तरं प्रारम्भिकनिर्देशिकासंरचना : १.

2. परियोजनासंरचनायाः परिवर्तनं कुर्वन्तु

प्रथमं भवद्भिः मूलनिर्देशिकसंरचना परिवर्तयितुं आवश्यकम्

१) मूलनिर्देशिकासंरचना

संपत्तियांचित्राणि पोस्ट कुर्वन्तु

घटकाःमध्यवर्ती घटकाः, प्रायः पुनः उपयोगयोग्याः

रूटरसर्वेषां मुख्यपृष्ठानां सञ्चिकामार्गाः यस्मिन् मार्गे विन्यस्ताः भवन्ति

संग्रहःसामान्यतया vuex राज्यप्रबन्धनार्थं प्रयुक्तम्, यथा टोकनस्य संग्रहणम् इत्यादि ।

दृश्यानिकेन्द्रं मुख्यपृष्ठम् अस्ति

App.vueइदं Vue अनुप्रयोगस्य मूलघटकम् अस्ति ।

मुख्य.जइयं अनुप्रयोगस्य प्रविष्टिसञ्चिका अस्ति, प्रायः vue, vue router इत्यादीनां आश्रयाणां परिचयार्थं उपयुज्यते ।

२) परिवर्तिता निर्देशिकासंरचना

प्रवेशः पञ्जीकरणकार्यं च कार्यान्वितुं परिवर्तिता निर्देशिकासंरचना अस्ति :


3. प्रवेशपञ्जीकरणपृष्ठं लिखन्तु

1)LoginAndRegister.vue

प्रवेशपञ्जीकरणपृष्ठं कार्याणि च कार्यान्वितुं घटकपुटस्य अधः LoginAndRegister.vue रचयन्तु अत्र, अहं केवलं प्रवेशस्य पञ्जीकरणस्य च कृते .vue सञ्चिकां रचयामि, यस्मिन् v-if इत्यस्य उपयोगः भवति यत् प्रवेशखण्डः पञ्जीकरणखण्डः च तत्त्वानि समाविष्टानि सन्ति वा इति .प्रतिपादनं, तस्मात् तेषां प्रदर्शनं प्रभावितं करोति।

प्रारम्भिकसेटिंग्स्

v-if="loginShow"为true, v-if="registerShow"为false

यदा बटनं टोग्ल् कर्तुं क्लिक् भवति तदा सत्यं असत्यं च टॉगलं करोति ।

सफलपञ्जीकरणानन्तरं पुनः प्रवेशविभागे गच्छन्तु ।

सुविधायै उपयोक्तृ-अभ्यासाय च यद्यपि उपयोक्तृ-विशेषणेषु id, username, password, phone, gender च सन्ति तथापि पञ्जीकरणस्य समये केवलं उपयोक्तृनाम गुप्तशब्दं च पूर्यते, तथा च कार्यं केवलं कार्यान्वितं भवति गुप्तशब्दः एन्क्रिप्टेड् नास्ति तथा च अस्ति पर्याप्तं सुरक्षितं नास्ति अहं पुनः लेखं अद्यतनं करिष्यामि यत् सुरक्षितप्रवेशपञ्जीकरणविधिविषये लिखितुं शक्नोमि, तथैव प्रवेशानन्तरं व्यक्तिगतसूचनाः कथं सुधारयितुम्।

LoginAndRegister.vue: 1.1.

  1. <template>
  2. <div class="container">
  3. <div class="login-box" v-if="loginShow">
  4. <!-- 菱形群-->
  5. <div class="decoration1 decoration"></div>
  6. <div class="decoration2 decoration"></div>
  7. <div class="decoration3 decoration"></div>
  8. <div class="decoration4 decoration"></div>
  9. <div class="decoration5 decoration"></div>
  10. <div class="decoration decoration4 decoration6"></div>
  11. <div class="decoration decoration7 decoration2"></div>
  12. <div class="decoration decoration8 decoration3"></div>
  13. <div class="login-title">
  14. <h1>Login</h1>
  15. </div>
  16. <div class="login-part">
  17. <input class="login-input" v-model="username" placeholder="Username" />
  18. <input class="login-input" type="password" v-model="password" placeholder="Password" />
  19. <button class="login-button" @click="login">Login</button>
  20. <div>
  21. 还未注册?点击<a class="change-link" @click="changeToRegister">这里</a>注册
  22. </div>
  23. </div>
  24. </div>
  25. <div class="login-box" v-if="registerShow">
  26. <!-- 菱形群-->
  27. <div class="decoration1 decoration"></div>
  28. <div class="decoration2 decoration"></div>
  29. <div class="decoration3 decoration"></div>
  30. <div class="decoration4 decoration"></div>
  31. <div class="decoration5 decoration"></div>
  32. <div class="decoration decoration4 decoration6"></div>
  33. <div class="decoration decoration7 decoration2"></div>
  34. <div class="decoration decoration8 decoration3"></div>
  35. <div class="login-title">
  36. <h1>Register</h1>
  37. </div>
  38. <div class="login-part">
  39. <input class="login-input" v-model="username" placeholder="Username" />
  40. <input class="login-input" type="password" v-model="password" placeholder="Password" />
  41. <button class="login-button" @click="register">Register</button>
  42. <span class="change-link" @click="changeToLogin">返回登录</span>
  43. </div>
  44. </div>
  45. <!-- <div class="decoration decoration1"></div>-->
  46. <!-- <div class="decoration decoration2"></div>-->
  47. <!-- <div class="decoration decoration3"></div>-->
  48. <!-- <div class="decoration decoration4"></div>-->
  49. </div>
  50. </template>
  51. <script>
  52. import { ref } from 'vue'
  53. import { useRouter } from 'vue-router' // 导入 useRouter
  54. import '../style/Login.css' // 导入css
  55. export default {
  56. name: 'LoginVue',
  57. setup () {
  58. const username = ref('')
  59. const password = ref('')
  60. const phone = ref('')
  61. const loginShow = ref(true)
  62. const registerShow = ref(false)
  63. const router = useRouter()
  64. const changeToRegister = async () => {
  65. loginShow.value = false
  66. registerShow.value = true
  67. }
  68. const changeToLogin = async () => {
  69. loginShow.value = true
  70. registerShow.value = false
  71. }
  72. const login = async () => {
  73. console.log('Login with:', username.value, password.value)
  74. try {
  75. const formData = new FormData()
  76. formData.append('username', username.value)
  77. formData.append('password', password.value)
  78. const response = await fetch('http://localhost:8081/api/user/login', {
  79. method: 'POST',
  80. body: formData
  81. })
  82. const data = await response.json()
  83. if (response.ok) {
  84. console.log('Link success', data)
  85. if (data.code === 200) {
  86. // 登录成功
  87. alert('登录成功!')
  88. await router.push('/home')
  89. } else {
  90. alert(data.msg)
  91. }
  92. } else {
  93. console.error('Link failed', data)
  94. }
  95. } catch (error) {
  96. console.error('Error login', error)
  97. }
  98. }
  99. const register = async () => {
  100. console.log('Register with:', username.value, password.value)
  101. try {
  102. const formData = new FormData()
  103. formData.append('username', username.value)
  104. formData.append('password', password.value)
  105. const response = await fetch('http://localhost:8081/api/user/register', {
  106. method: 'POST',
  107. body: formData
  108. })
  109. const data = await response.json()
  110. if (response.ok) {
  111. if (data.code === 200) {
  112. console.log('Register success', data)
  113. alert('注册成功!')
  114. await changeToLogin()
  115. } else {
  116. console.log('Register failed', data)
  117. alert(data.msg)
  118. }
  119. } else {
  120. console.error('Register failed', data)
  121. }
  122. } catch (error) {
  123. console.error('Error during register', error)
  124. }
  125. }
  126. return { username, password, phone, login, loginShow, registerShow, changeToRegister, register, changeToLogin }
  127. }
  128. }
  129. </script>
  130. <style>
  131. </style>

२)गृहम् ।vue

Home.vue इति मुख्यपृष्ठं यत् सफलप्रवेशानन्तरं कूर्दति ।

Home.vue: .

  1. <template>
  2. 首页<br><br>
  3. <button class="login-button" @click="signOut">退出登录</button>
  4. </template>
  5. <script>
  6. import { useRouter } from 'vue-router'
  7. export default {
  8. name: 'HomeVue',
  9. setup () {
  10. const router = useRouter()
  11. const signOut = async () => {
  12. await router.push('/')
  13. }
  14. return { signOut }
  15. }
  16. }
  17. </script>
  18. <style scoped>
  19. </style>

३)रूटरः

पृष्ठमार्गविन्यासविन्यासः, यदा मार्गः /, /login प्रवेशपृष्ठं, /home च गृहपृष्ठं भवति तदा प्रवेशपृष्ठं प्रति पुनर्निर्देशनं कुर्वन्तु ।

अनुक्रमणिका.ज्स्: .

  1. import { createRouter, createWebHistory } from 'vue-router'
  2. import Login from '../components/LoginAndRegister.vue'
  3. import Home from '../views/Home.vue'
  4. const routes = [
  5. {
  6. path: '/',
  7. redirect: '/login'
  8. },
  9. {
  10. path: '/login',
  11. name: 'Login',
  12. component: Login
  13. },
  14. {
  15. path: '/home',
  16. name: 'Home',
  17. component: Home
  18. }
  19. ]
  20. const router = createRouter({
  21. history: createWebHistory(process.env.BASE_URL),
  22. routes
  23. })
  24. export default router

४)प्रवेशः ।css

प्रवेशपञ्जीकरणपृष्ठस्य कृते CSS डिजाइनम् ।

प्रवेशः.css:

  1. *{
  2. margin: 0;
  3. padding: 0;
  4. }
  5. .container{
  6. height: 100vh;
  7. display: flex;
  8. justify-content: center;
  9. align-items: center;
  10. overflow: hidden;
  11. position: relative;
  12. }
  13. .login-box{
  14. background-color: white;
  15. padding: 40px 100px;
  16. border-radius: 8px;
  17. box-shadow: 0 0 5px 1px gainsboro;
  18. position: relative;
  19. }
  20. .login-part{
  21. display: flex;
  22. flex-direction: column;
  23. justify-content: center;
  24. margin-top: 20px;
  25. gap: 20px;
  26. }
  27. .login-input{
  28. width: 250px;
  29. height: 30px;
  30. border-radius: 8px;
  31. }
  32. .login-button{
  33. height: 40px;
  34. border-radius: 8px;
  35. background-color: #2c3e50;
  36. color: white;
  37. transition: 0.5s;
  38. }
  39. .login-button:hover{
  40. background-color: darkcyan;
  41. font-size: 15px;
  42. transition: 0.5s;
  43. }
  44. .login-button:active{
  45. background-color: darkslateblue;
  46. }
  47. .change-link{
  48. color: #00BFFF;
  49. text-decoration: underline;
  50. }
  51. .change-link:hover{
  52. color: cornflowerblue;
  53. }
  54. .decoration {
  55. position: absolute;
  56. width: 200px;
  57. height: 200px;
  58. background: linear-gradient(to left, #FDF5E6, #96CDCD );
  59. clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
  60. z-index: 1;
  61. }
  62. .decoration1 {
  63. top: 150px;
  64. left: -210px;
  65. }
  66. .decoration2 {
  67. top: 20px;
  68. right: -20px;
  69. width: 100px; /* 第二个菱形的大小 */
  70. height: 100px;
  71. background: linear-gradient(to right, #FFF5EE, #E6E6FA);
  72. }
  73. .decoration3 {
  74. top: 50px;
  75. right: -180px;
  76. width: 200px; /* 第三个菱形的大小 */
  77. height: 200px;
  78. background: linear-gradient(to right, #7FFFD4, cadetblue);
  79. }
  80. .decoration4 {
  81. top: 200px;
  82. right: -200px;
  83. width: 500px; /* 第三个菱形的大小 */
  84. height: 500px;
  85. z-index: -1;
  86. clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
  87. background: linear-gradient(to right, #FFFACD, #00BFFF);
  88. }
  89. .decoration5 {
  90. top: -100px;
  91. right: 200px;
  92. width: 400px; /* 第三个菱形的大小 */
  93. height: 400px;
  94. z-index: -1;
  95. clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
  96. background: linear-gradient(to right, #AFEEEE, #00BFFF);
  97. }
  98. .decoration6 {
  99. top: 10px;
  100. right: -680px;
  101. }
  102. .decoration7 {
  103. top: -170px;
  104. right: -500px;
  105. }
  106. .decoration8 {
  107. top: -140px;
  108. right: -655px;
  109. }

५) प्रवेशपञ्जीकरणपृष्ठप्रदर्शनम्

हीरकरूपेण खण्डाः यादृच्छिकरूपेण व्यवस्थापिताः भवन्ति, आरम्भे ते एतादृशाः दृश्यन्ते ।

पश्चात् मया कतिपयानि अधिकानि हीरक-आकार-खण्डानि योजयित्वा तेषां स्थानानि वर्णाः च परिवर्तिताः अन्तिमः प्रभावः निम्नलिखितरूपेण अस्ति ।

2. springboot+mysql+mybatis परियोजनां रचयन्तु तथा च आँकडाधारेण सह सम्बद्धं कुर्वन्तु

केवलं पृष्ठ-अन्त-प्रकल्पं निर्मातुं तथा च आँकडाधारेण सह सम्बद्धं कर्तुं springboot, mysql, mybatis इत्येतयोः उपयोगं कुर्वन्तु, सन्दर्भः:

idea, spring boot+MySQL+MyBatis परियोजना जालपुटे आँकडाधारसारणीयाः सामग्रीं निर्माय प्रदर्शयति_idea जालपुटे-CSDN Blog इत्यत्र आँकडाधारं प्रदर्शयति

लेखस्य पूरकम् : १.

यदि भवान् प्रत्येकं एण्टिटी क्लास् निर्माय set इति लिखितुं मेथड् प्राप्तुं च कष्टं अनुभवति तर्हि pom.xml मध्ये निम्नलिखितनिर्भरताः योजयितुं शक्नोति ।

  1. <dependency>
  2. <groupId>org.projectlombok</groupId>
  3. <artifactId>lombok</artifactId>
  4. </dependency>

ततः सेट् लेखनं त्यक्त्वा मेथड्स् प्राप्तुं entity क्लास् मध्ये @Data एनोटेशनस्य उपयोगं कुर्वन्तु:

प्रक्रिया प्रायः समाना एव, परन्तु अस्मिन् समये मया निर्मितः दत्तांशः भिन्नः अस्ति मुख्यकारणं यत् उपयोक्तृसारणी विशेषताः दत्तांशः च परिवर्तितः (अन्तरं महत् नास्ति, सूपः च औषधं न परिवर्तयति):

समस्यायाः सम्मुखीभूय: maven आश्रयान् अवतरणं कुर्वन् अस्ति, परन्तु दीर्घकालं यावत् प्रतिक्रिया नास्ति

तथापि परियोजनायाः निर्माणकाले किमपि भ्रष्टं जातम् अस्मिन् समये अहं प्रथमवारं मया निर्मितम् आसीत् फलतः Maven इत्यस्य आरम्भस्य अनन्तरं विविधानि आश्रयाणि प्लग् च डाउनलोड् कुर्वन् आसीत् -ins, तथा च दीर्घकालं यावत् प्रतिक्रिया नासीत्:

समाधानं:

अहं सञ्चयं स्वच्छं कृत्वा विचारं पुनः आरब्धवान्, परन्तु तस्य अल्पः प्रभावः अभवत् ।

पश्चात् मया आविष्कृतं यत् एतत् भवितुं शक्नोति यतोहि Maven पूर्वनिर्धारितरूपेण विदेशीयस्य केन्द्रीयगोदामस्य उपयोगं करोति, अहं च विचारे maven प्लग-इन् इत्यस्य उपयोगं कुर्वन् आसीत्, अतः डाउनलोड् गतिः अतीव मन्दः भविष्यति

अतः अहं maven स्थानीयरूपेण डाउनलोड् कृतवान्, पाठ्यक्रमं पश्यन्तु:

Maven डाउनलोड् तथा संस्थापन पाठ्यक्रम (सुपर विस्तृत)_maven संस्थापन-CSDN ब्लॉग

पाठ्यक्रमानुसारं डाउनलोड् कुर्वन्तु तथा च maven संस्थापनमार्गे-&gt;conf-&gt;settings.xml इत्यस्मिन् चित्रस्य URL परिवर्तयन्तु तथापि, अहं प्रत्यक्षतया file-&gt;settings-&gt; इत्यस्मिन् विचारे सेट् न कृतवान् Build, Execution, Deployment-&gt;Build Tools-&gt; Maven इत्यस्मिन् Maven गृहमार्गं स्थानीयमार्गे परिवर्तयन्तु:

परिवर्तनानन्तरं डाउनलोड् वेगः खलु बहु द्रुततरः भवति ।

अन्तिमपृष्ठभागप्रकल्पस्य निर्देशिकासंरचना निम्नलिखितरूपेण अस्ति ।

3. लॉगिन् तथा पञ्जीकरणपृष्ठ-अन्त-कार्यं लिखन्तु

1. प्रवेश तर्कः

अग्रभागेन पारितां पूरितां सूचनां प्राप्नुवन्तु, यत्र उपयोक्तृनाम गुप्तशब्दः च सन्ति, तथा च दत्तांशकोशे उपयोक्तृनाम गुप्तशब्दाधारितं प्रश्नं कुर्वन्तु यदि उपयोक्ता लभ्यते तर्हि उपयोक्ता अस्ति इति अर्थः .प्रवेशः सफलः भवति, अन्यथा विफलः भवति ।

2. पञ्जीकरणतर्कः

अग्रभागेन पारितां पूरणसूचनाः प्राप्नुवन्तु, यत्र उपयोक्तृनाम गुप्तशब्दः च सन्ति इति निर्णयानन्तरं प्रथमं दत्तांशकोशे उपयोक्तृनामनुसारं उपयोक्तारं अन्वेष्टुम् विफलतां प्राप्नोति तथा च विफलतायाः सूचना प्रत्यागच्छति तर्हि उपयोक्तारः पञ्जीकरणं कृत्वा अभिलेखं सफलपञ्जीकरणानन्तरं प्रवेशखण्डं प्रदर्शितं भविष्यति तथा च पञ्जीकरणखण्डः गोपनीयः भविष्यति।

3. बैकएण्ड् कोड भाग

तेषु संसाधनं-&gt;mapper-&gt;UserMapper.xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  3. "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
  4. <mapper namespace="com.example.demo.mapper.UserMapper" >
  5. <resultMap id="result" type="com.example.demo.entity.User">
  6. <result property="id" column="id" />
  7. <result property="username" column="username" />
  8. <result property="password" column="password" />
  9. <result property="phone" column="phone" />
  10. <result property="gender" column="gender"/>
  11. </resultMap>
  12. <!-- 通过用户名和密码查找对应用户,用于登录-->
  13. <select id="findUserByNameAndPwd" resultMap="result" parameterType="User">
  14. select * from user
  15. where username = #{username}
  16. and password = #{password}
  17. </select>
  18. <!-- 通过用户名查找对应用户,用于注册检验用户名是否已存在-->
  19. <select id="findUserByName" resultMap="result" parameterType="User">
  20. select * from user
  21. where username = #{username}
  22. </select>
  23. <!-- 添加用户-->
  24. <insert id="addUser" parameterType="User">
  25. insert into user (username, password)
  26. values ( #{username}, #{password} )
  27. </insert>
  28. </mapper>

जावा-&gt; कॉम.उदाहरण.डेमो-&gt; मैपर-&gt; यूजरमैपर.जावा:

  1. package com.example.demo.mapper;
  2. import com.example.demo.entity.User;
  3. import org.apache.ibatis.annotations.Mapper;
  4. @Mapper
  5. public interface UserMapper {
  6. // 通过用户名和密码查找对应用户
  7. public User findUserByNameAndPwd(User user);
  8. // 通过用户名查找用户
  9. public User findUserByName(User user);
  10. // 添加用户
  11. public void addUser(User user);
  12. }

जावा-&gt; कॉम.उदाहरण.डेमो-&gt; सेवा-&gt;उपयोक्तृसेवा.जावा:

  1. package com.example.demo.service;
  2. import com.example.demo.entity.User;
  3. public interface UserService {
  4. // 通过用户名和密码查找对应id
  5. public User findUserByNameAndPwd(User user);
  6. // 通过用户名查找用户
  7. public User findUserByName(User user);
  8. // 添加用户
  9. public void addUser(User user);
  10. }

जावा-&gt; कॉम.उदाहरण.डेमो-&gt; सेवा-&gt;उपयोक्तृसेवाइम्पल.जावा:

  1. package com.example.demo.service;
  2. import com.example.demo.entity.User;
  3. import com.example.demo.mapper.UserMapper;
  4. import jakarta.annotation.Resource;
  5. import org.springframework.stereotype.Service;
  6. @Service
  7. public class UserServiceImpl implements UserService {
  8. @Resource
  9. private UserMapper userMapper;
  10. // 通过用户名和密码查找对应id
  11. @Resource
  12. public User findUserByNameAndPwd(User user){
  13. return userMapper.findUserByNameAndPwd(user);
  14. }
  15. // 通过用户名查找用户
  16. @Resource
  17. public User findUserByName(User user){
  18. return userMapper.findUserByName(user);
  19. }
  20. // 添加用户
  21. @Resource
  22. public void addUser(User user){
  23. userMapper.addUser(user);
  24. }
  25. }

जावा-&gt; कॉम.उदाहरण.डेमो-&gt; नियंत्रक-&gt; उपयोक्तृनियंत्रक.जावा:

  1. package com.example.demo.controller;
  2. import com.example.demo.entity.User;
  3. import com.example.demo.result.Result;
  4. import com.example.demo.service.UserService;
  5. import jakarta.annotation.Resource;
  6. import org.springframework.web.bind.annotation.*;
  7. @RestController
  8. @RequestMapping("/api/user")
  9. public class UserController {
  10. @Resource
  11. UserService userService;
  12. // 登录
  13. @CrossOrigin
  14. @PostMapping(value = "/login")
  15. public Result login(@ModelAttribute("user") User user){
  16. String username=user.getUsername();
  17. String password=user.getPassword();
  18. System.out.println("Login received username: " + username);
  19. System.out.println("Login received password: " + password);
  20. User userCheck = new User();
  21. userCheck.setUsername(username);
  22. userCheck.setPassword(password);
  23. System.out.println(userCheck.getUsername() + " " + userCheck.getPassword());
  24. try{
  25. User findUser = userService.findUserByNameAndPwd(userCheck);
  26. if(findUser != null){
  27. return Result.success(findUser);
  28. }else {
  29. return Result.failure(401,"用户名或密码错误");
  30. }
  31. }catch (Exception e){
  32. return Result.failure(500,"服务器异常");
  33. }
  34. }
  35. // 注册
  36. @CrossOrigin
  37. @PostMapping(value = "/register")
  38. public Result register(@ModelAttribute("user") User user){
  39. // String username = "222";
  40. // String password = "222";
  41. User userCheck = new User();
  42. userCheck.setUsername(user.getUsername());
  43. userCheck.setPassword(user.getPassword());
  44. if(userCheck.getUsername() == null || userCheck.getUsername().isEmpty() || userCheck.getPassword() == null || userCheck.getPassword().isEmpty()){
  45. System.out.println("用户名或密码不可为空");
  46. return Result.failure(201,"用户名和密码不可为空");
  47. }else {
  48. System.out.println("Register received username: " + userCheck.getUsername());
  49. System.out.println("Register received password: " + userCheck.getPassword());
  50. try{
  51. // 先在数据库中查找是否已有用户名相同的用户
  52. User findUser = userService.findUserByName(userCheck);
  53. if(findUser != null){
  54. // 用户名已存在
  55. return Result.failure(202,"用户名已存在!");
  56. }
  57. else {
  58. // 新用户,数据库添加记录
  59. userService.addUser(userCheck);
  60. return Result.success(userCheck);
  61. }
  62. }catch (Exception e) {
  63. return Result.failure(500, "服务器异常");
  64. // }
  65. }
  66. }
  67. }
  68. }

4. परियोजनां चालयन्तु

अग्रे पृष्ठे च पृथक् पृथक् चालिताः आरब्धाः च अत्र अहं application.properties इत्यस्मिन् पृष्ठभागं 8081 इति परिवर्तितवान्, अग्रभागः च पूर्वनिर्धारितः 8080 अस्ति अतः अग्रे पृष्ठे च परियोजना सफलतया चालितस्य अनन्तरं http:/ इति प्रविष्टं कुर्वन्तु । /localhost:8080 ब्राउजर् मध्ये , विकासकसाधनानाम् संजाले तस्य जाँचं कुर्वन्तु, पृष्ठभागे सफलतया संयोजयन्तु, तथा च परीक्षणनिवेशार्थं प्रवेशं कुर्वन् पञ्जीकरणं कुर्वन्तः भिन्नाः प्रॉम्प्ट् सूचनाः पॉप-अप-प्रोम्प्ट् च सफलतया प्रत्यागच्छन्तु:

सफलप्रवेशानन्तरं : १.