/*
* Copyright 2002-2006 the original author or authors.
*
* 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 org.openuap.cms.user.action.edit;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.openuap.base.util.ControllerHelper;
import org.openuap.base.util.StringUtil;
import org.openuap.cms.user.action.UserBaseAction;
import org.openuap.cms.user.model.IUser;
import org.springframework.web.servlet.ModelAndView;
/**
* <p>
* 修改密码控制器.
* </p>
*
* <p>
* $Id: UserChangePwdAction.java 3992 2011-01-05 06:34:18Z orangeforjava $
* </p>
*
* @author Joseph
* @version 1.0
*/
public class UserChangePwdAction extends UserBaseAction {
//
private String defaultScreensPath;
private String defaultViewName;
private String resultViewName;
//
public UserChangePwdAction() {
initDefaultProperty();
}
protected void initDefaultProperty() {
defaultScreensPath = "/plugin/cms/base/screens/user/edit/";
defaultViewName = defaultScreensPath + "user_changepwd.htm";
resultViewName = defaultScreensPath + "user_result.html";
}
public ModelAndView beforePerform(HttpServletRequest request,
HttpServletResponse response, ControllerHelper helper, Map model)
throws Exception {
ModelAndView mv = super.beforePerform(request, response, helper, model);
if (mv != null) {
return mv;
}
// 修改密码必须登录
if (!this.isLogin()) {
//
return this.loginForm(request, response, helper, model);
}
//
return null;
}
public ModelAndView perform(HttpServletRequest request,
HttpServletResponse response, ControllerHelper helper, Map model)
throws Exception {
ModelAndView mv = new ModelAndView(defaultViewName, model);
IUser user=this.getUser();
model.put("user",user);
return mv;
}
public ModelAndView doChange(HttpServletRequest request,
HttpServletResponse response, ControllerHelper helper, Map model)
throws Exception {
ModelAndView mv = new ModelAndView(resultViewName, model);
model.put("op", "changePwd");
try {
IUser user = this.getUser();
String passwordOld = request.getParameter("passwordOld");
if (passwordOld != null) {
String pold = getDigestedPassword(passwordOld);
if (!pold.equals(user.getPassword())) {
model.put("rs", "failed");
model.put("msgs", "原密码不正确!");
return mv;
}
}
String password = request.getParameter("password");
password = getDigestedPassword(password);
//
user.setPassword(password);
this.getUserManager().saveUser(user);
// TODO 同步信息,向通行证发送密码同步消息
//
model.put("rs", "success");
} catch (Exception ex) {
model.put("rs", "failed");
model.put("msgs", ex);
}
return mv;
}
public void setResultViewName(String resultViewName) {
this.resultViewName = resultViewName;
}
public String getDigestedPassword(String password) {
return StringUtil.digest(password, "MD5");
}
public void setDefaultViewName(String defaultViewName) {
this.defaultViewName = defaultViewName;
}
public void setDefaultScreensPath(String defaultScreensPath) {
this.defaultScreensPath = defaultScreensPath;
}
}