您
userdata [Map]对我的用法看起来不对。它是用户类的一部分,是非静态还是静态的?如果它是非静态的,那么每次您将执行
newUser()该映射时,该映射将被初始化,并且其中将没有数据。因此
u1.userdata.containsKey(emailc);将永远是错误的。
如果您出于开发目的将哈希图用作临时数据库,则使其为静态,而不是将其保留在其他类(如UserStore或某些数据库访问层)中。示例如下:
public class UserDAO(){private static Map<String,User> userdata = new HashMap<String,User>();public boolean hasUser(String email){ return userdata.contains(email);}public User saveUser(String email, String password ...){//make user object save it in map and return the same}// more methods for delete and edit etc.}并在这样的REST层类中使用它
exists = userDao.hasUser(email);
优点 :
- 您的问题将得到解决。
- 稍后,当您转向实际的数据库实现时,只需更改UserDao代码,其余应用程序代码就可以了。-松耦合:)
也关于转发使用电子邮件
servletResponse.sendRedirect("http://localhost:8080/MySite/{email}"); <<<< How to redirect using @FormParam("email")如果您想要的是,仅在url中添加email参数:
servletResponse.sendRedirect("http://localhost:8080/MySite/"+emailc);更新:
看到的根本是,您获得了请求参数
[email , password]。您检查它是否存在于地图中。现在您在这里做错了,您需要像这样创建一个新用户
Useru = new User();,然后从中获取电子邮件和密码
emailc =u.getEmail();。这
emailc将永远如此
null,您
userdata map将永远
false为此而归。您有两种选择:
- 在用户对象中设置电子邮件和密码,然后从用户对象获取数据。
- 使用从请求参数获得的电子邮件和密码进行逻辑处理。不要改变它们
编程时要遵循的一种好习惯是,始终将您的方法参数视为最终参数。
更新2:
if(mypass==pass){ checked=true; }else{ checked=false; }更改
==为
equals方法。
String matching应该由
equals或
equalsIgnoreCase方法而非==完成。



