JSP网店软件源代码共享

分析国内JSP网店软件,小有名气的如:SHOP++、全网、博商。通过了解,全网和博商是不对客户提供源代码的,SHOP++对商业授权用户提供全部源代码,下面会分享SHOP++部分源代码,希望可以帮助在学习JSP技术的人员,但承诺对此源代码不负任何形式的负责,以下代码仅提供学习用,有需求,可以上官网去了解,获得正版本软件源代码。

package net.shopxx.action.admin;

import java.util.HashSet;
import java.util.List;

import javax.annotation.Resource;

import net.shopxx.entity.Admin;
import net.shopxx.entity.Role;
import net.shopxx.service.AdminService;
import net.shopxx.service.RoleService;

import org.apache.commons.codec.digest.DigestUtils;
import org.apache.commons.lang.StringUtils;
import org.apache.struts2.convention.annotation.ParentPackage;
import org.springframework.beans.BeanUtils;

import com.opensymphony.xwork2.interceptor.annotations.InputConfig;
import com.opensymphony.xwork2.validator.annotations.EmailValidator;
import com.opensymphony.xwork2.validator.annotations.RegexFieldValidator;
import com.opensymphony.xwork2.validator.annotations.RequiredStringValidator;
import com.opensymphony.xwork2.validator.annotations.StringLengthFieldValidator;
import com.opensymphony.xwork2.validator.annotations.Validations;

/**
 * 后台Action类 - 管理员
 * ============================================================================
 * 版权所有 2008-2010 长沙鼎诚软件有限公司,并保留所有权利。
 * ----------------------------------------------------------------------------
 * 提示:在未取得SHOP++商业授权之前,您不能将本软件应用于商业用途,否则SHOP++将保留追究的权力。
 * ----------------------------------------------------------------------------
 * 官方网站:http://www.shopxx.net
 * ----------------------------------------------------------------------------
 * KEY: SHOPXXE5A2C60595A4C64534D70AC9A5B94FD
 * ============================================================================
 */

@ParentPackage("admin")
public class AdminAction extends BaseAdminAction {

 private static final long serialVersionUID = -6296393115930477663L;
 
 private Admin admin;
 private List<Role> roleList;

 @Resource(name = "adminServiceImpl")
 private AdminService adminService;
 @Resource(name = "roleServiceImpl")
 private RoleService roleService;
 
 // 是否已存在 ajax验证
 public String checkUsername() {
  String username = admin.getUsername();
  if (adminService.isExistByUsername(username)) {
   return ajax("false");
  } else {
   return ajax("true");
  }
 }

 // 添加
 public String add() {
  return INPUT;
 }

 // 编辑
 public String edit() {
  admin = adminService.load(id);
  return INPUT;
 }

 // 列表
 public String list() {
  pager = adminService.findPager(pager);
  return LIST;
 }

 // 删除
 public String delete() {
  if (ids.length >= adminService.getTotalCount()) {
   return ajax(Status.error, "请至少保留一个管理员,删除失败!");
  }
  StringBuffer logInfoStringBuffer = new StringBuffer("删除管理员: ");
  for (String id : ids) {
   Admin admin = adminService.load(id);
   adminService.delete(admin);
   logInfoStringBuffer.append(admin.getUsername() + " ");
  }
  logInfo = logInfoStringBuffer.toString();
  return ajax(Status.success, "删除成功!");
 }

 // 保存
 @Validations(
  requiredStrings = {
   @RequiredStringValidator(fieldName = "admin.username", message = "用户名不允许为空!"),
   @RequiredStringValidator(fieldName = "admin.password", message = "密码不允许为空!"),
   @RequiredStringValidator(fieldName = "admin.email", message = "E-mail不允许为空!")
  },
  stringLengthFields = {
   @StringLengthFieldValidator(fieldName = "admin.username", minLength = "2", maxLength = "20", message = "用户名长度必须在${minLength}到${maxLength}之间!"),
   @StringLengthFieldValidator(fieldName = "admin.password", minLength = "4", maxLength = "20", message = "密码长度必须在${minLength}到${maxLength}之间!")
  },
  emails = {
   @EmailValidator(fieldName = "admin.email", message = "E-mail格式错误!")
  },
  regexFields = {
   @RegexFieldValidator(fieldName = "admin.username", expression = "^[0-9a-z_A-Z\u4e00-\u9fa5]+$", message = "用户名只允许包含中文、英文、数字和下划线!")
  }
 )
 @InputConfig(resultName = "error")
 public String save() {
  if (adminService.isExistByUsername(admin.getUsername())) {
   addActionError("用户名已存在!");
   return ERROR;
  }
  
  if (roleList == null || roleList.size() == 0) {
   addActionError("管理角色不允许为空!");
   return ERROR;
  }
  admin.setUsername(admin.getUsername().toLowerCase());
  admin.setLoginFailureCount(0);
  admin.setIsAccountLocked(false);
  admin.setIsAccountExpired(false);
  admin.setIsCredentialsExpired(false);
  admin.setRoleSet(new HashSet<Role>(roleList));
  String passwordMd5 = DigestUtils.md5Hex(admin.getPassword());
  admin.setPassword(passwordMd5);
  adminService.save(admin);
  logInfo = "添加管理员: " + admin.getUsername();
  redirectUrl = "admin!list.action";
  return SUCCESS;
 }

 // 更新
 @Validations(
  requiredStrings = {
   @RequiredStringValidator(fieldName = "admin.username", message = "用户名不允许为空!"),
   @RequiredStringValidator(fieldName = "admin.email", message = "E-mail不允许为空!")
  },
  stringLengthFields = {
   @StringLengthFieldValidator(fieldName = "admin.username", minLength = "2", maxLength = "20", message = "用户名长度必须在${minLength}到${maxLength}之间!"),
   @StringLengthFieldValidator(fieldName = "admin.password", minLength = "4", maxLength = "20", message = "密码长度必须在${minLength}到${maxLength}之间!") },
  emails = {
   @EmailValidator(fieldName = "admin.email", message = "E-mail格式错误!")
  },
  regexFields = {
   @RegexFieldValidator(fieldName = "admin.username", expression = "^[0-9a-z_A-Z\u4e00-\u9fa5]+$", message = "用户名只允许包含中文、英文、数字和下划线!")
  }
 )
 @InputConfig(resultName = "error")
 public String update() {
  Admin persistent = adminService.load(id);
  if (roleList == null || roleList.size() == 0) {
   addActionError("管理角色不允许为空!");
   return ERROR;
  }
  admin.setRoleSet(new HashSet<Role>(roleList));
  if (StringUtils.isNotEmpty(admin.getPassword())) {
   String passwordMd5 = DigestUtils.md5Hex(admin.getPassword());
   persistent.setPassword(passwordMd5);
  }
  BeanUtils.copyProperties(admin, persistent, new String[] {"id", "createDate", "modifyDate", "username", "password", "isAccountLocked", "isAccountExpired", "isCredentialsExpired", "loginFailureCount", "lockedDate", "loginDate", "loginIp", "authorities"});
  adminService.update(persistent);
  logInfo = "编辑管理员: " + admin.getUsername();
  redirectUrl = "admin!list.action";
  return SUCCESS;
 }
 
 // 获取所有管理权限集合
 public List<Role> getAllRoleList() {
  return roleService.getAllList();
 }

 public Admin getAdmin() {
  return admin;
 }

 public void setAdmin(Admin admin) {
  this.admin = admin;
 }

 public List<Role> getRoleList() {
  return roleList;
 }

 public void setRoleList(List<Role> roleList) {
  this.roleList = roleList;
 }

}

转载于:https://my.oschina.net/u/197430/blog/60140

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值