java網(wǎng)上商城項目第1篇之用戶注冊模塊
本文為大家講解了商城項目用戶注冊模塊,供大家參考,先看看效果圖:
1.前臺JS校驗:
事件觸發(fā): onsubmit=”checkForm()”
2.使用AJAX完成異步用戶名是否存在校驗
①事件觸發(fā):onblur=”checkUserName()”
②AJAX
function checkUsername(){ var username = $("#username").val(); $("#span1").load("${pageContext.request.contextPath}/user_checkUsername.action",{'username':username}); }
3.后臺Struts2的數(shù)據(jù)校驗
①.編寫表單中的<form action=”${ pageContext.request.contextPath }/user_regist.action”/>
②.在Action中編寫方法
③.完成數(shù)據(jù)校驗:
在Action所在包下創(chuàng)建一個類名-方法對應(yīng)訪問路徑-validation.xml
UserAction-user_regist-validation.xml
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE validators PUBLIC "-//Apache Struts//XWork Validator 1.0.3//EN" "http://struts.apache.org/dtds/xwork-validator-1.0.3.dtd"> <validators> <!-- name:要校驗的字段名 --> <field name="username"> <field-validator type="requiredstring"> <message>用戶名不能為空!</message> </field-validator> </field> <!-- name:要校驗的字段名 --> <field name="password"> <field-validator type="requiredstring"> <message>密碼不能為空!</message> </field-validator> </field> <!-- 校驗郵箱 --> <field name="email"> <field-validator type="email"> <message>郵箱格式不正確!</message> </field-validator> </field> <!-- 校驗電話 --> <field name="phone"> <field-validator type="regex"> <param name="regex"><![CDATA[^15\d{9}$]]></param> <message>電話不合法</message> </field-validator> </field> </validators>
4.發(fā)送激活郵件
① 引入兩個包: activation.jarmail.jar
②UserService.java
/** * 注冊用戶的方法 * @param user */ public void save(User user) { // 保存到數(shù)據(jù)庫: user.setState(0); // 0:未激活 1:已經(jīng)激活 String code = UUIDUtils.getUUID()+UUIDUtils.getUUID(); user.setCode(code); userDao.save(user); // 發(fā)送一封激活郵件: MailUtils.sendMail(user.getEmail(), code); }
③MailUtils
/** * 發(fā)送郵件方法: */ public static void sendMail(String to,String code){ Properties props = new Properties(); props.setProperty("mail.smtp", "localhost"); // 1.獲得連接: Session session = Session.getInstance(props, new Authenticator() { @Override protected PasswordAuthentication getPasswordAuthentication() { return new PasswordAuthentication("service@shop.com", "111"); } }); // 2.創(chuàng)建一個郵件的對象 Message message = new MimeMessage(session); // 設(shè)置發(fā)件人: try { message.setFrom(new InternetAddress("service@shop.com")); // 設(shè)置收件人: message.setRecipient(RecipientType.TO, new InternetAddress(to)); // 設(shè)置主題: message.setSubject("來自ITCASTSHOP商城激活郵件"); // 設(shè)置郵件正文: message.setContent("<h1>來自ITCASTSHOP購物天堂的激活郵件</h1><h3><a text/html;charset=UTF-8"); // 發(fā)送郵件: Transport.send(message); } catch (AddressException e) { e.printStackTrace(); } catch (MessagingException e) { e.printStackTrace(); } }
5.用戶激活
在郵箱中點擊連接提交到Action.
Action中接收激活碼:
按照激活碼查詢這個用戶:
* 如果查詢到了:
* 修改用戶狀態(tài)
* 如果沒有用戶:
* 激活失敗:
/** * 用戶激活的方法: */ public String active() { // 模型驅(qū)動會接收激活碼: // 按照激活碼查詢用戶 : User existUser = userService.findByCode(user.getCode()); if (existUser == null) { // 激活碼篡改 this.addActionMessage("激活失敗:激活碼被篡改了!"); } else { // 激活:修改用戶狀態(tài) existUser.setState(1); userService.update(existUser); // 激活成功: this.addActionMessage("激活成功:請去登錄!"); } return "msg"; }
github完整代碼:https://github.com/ganchuanpu/itcastshop
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java數(shù)組聲明、創(chuàng)建、初始化基礎(chǔ)
本文講述了Java數(shù)組的幾個相關(guān)的方面,講述了對Java數(shù)組的聲明、創(chuàng)建和初始化,并給出其對應(yīng)的代碼2012-12-12Mybatis詳解動態(tài)SQL以及單表多表查詢的應(yīng)用
MyBatis的動態(tài)SQL是基于OGNL表達式的,它可以幫助我們方便的在SQL語句中實現(xiàn)某些邏輯,下面這篇文章主要給大家介紹了關(guān)于Mybatis超級強大的動態(tài)SQL語句的相關(guān)資料,需要的朋友可以參考下2022-06-06spring-boot 多線程并發(fā)定時任務(wù)的解決方案
這篇文章主要介紹了spring-boot 多線程并發(fā)定時任務(wù)的解決方案,需要的朋友可以參考下2019-08-08SpringBoot整合sharding-jdbc實現(xiàn)自定義分庫分表的實踐
本文主要介紹了SpringBoot整合sharding-jdbc實現(xiàn)自定義分庫分表的實踐,將通過自定義算法來實現(xiàn)定制化的分庫分表來擴展相應(yīng)業(yè)務(wù),感興趣的可以了解一下2021-11-11SpringBoot啟動security后如何關(guān)閉彈出的/login頁面
這篇文章主要介紹了SpringBoot啟動security后如何關(guān)閉彈出的login頁面問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12Java窗體動態(tài)加載磁盤文件的實現(xiàn)方法
這篇文章主要介紹了Java窗體動態(tài)加載磁盤文件的實現(xiàn)方法,需要的朋友可以參考下2014-03-03Java 網(wǎng)絡(luò)編程之 TCP 實現(xiàn)簡單的聊天系統(tǒng)
這篇文章主要介紹了Java 網(wǎng)絡(luò)編程之 TCP 實現(xiàn)簡單的聊天系統(tǒng),幫助大家更好的理解和學(xué)習(xí)Java 網(wǎng)絡(luò)編程,感興趣的朋友可以了解下2020-11-11