- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Android Studio 在 Debian Jessie 上构建一个 Android 应用程序。我希望能够实现一个电子邮件验证系统,当用户注册时,他们将自动收到一封包含链接的电子邮件。单击该链接会将数据库中的值从 false 更改为 true,以便对用户进行身份验证。
我听说我可以使用 JavaMail API 来完成这个?但同时听说我需要在本地主机上运行一个电子邮件服务器才能发送电子邮件?
我还没有找到明确的答案。任何帮助将不胜感激。谢谢。
最佳答案
可能我不知道对此的最佳答案。有两种方法可以做到这一点。
使用网络服务发送验证邮件。即假设您正在使用 PHP 网络服务来注册用户。当用户详细信息成功存储在数据库中时...您可以生成一个随机代码...将邮件发送到注册的电子邮件地址...在响应中获取该代码...并将其存储在首选项中以检查有效性.. 当用户输入时。
注册成功后....您可以通过触发某些对话框或任何其他方式向用户发送验证码...这是我的代码。我正在使用 volley 进行网络通话。
公共(public)类 DialogRequestPassword 扩展了 Dialog 实现 android.view.View.OnClickListener {
public Activity c;
private PreferencesManager preferencesManager;
DatabaseHelper db;
private ProgressDialog progressDialog;
EditText request_password;
public DialogRequestPassword(Activity a) {
super(a);
this.c = a;
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.dialog_request_password);
setCancelable(false);
preferencesManager = new PreferencesManager(c);
db = new DatabaseHelper(c);
progressDialog = new ProgressDialog(c);
progressDialog.setCancelable(false);
progressDialog.setMessage("Getting Information...");
TextView connectButton = (TextView) findViewById(R.id.connectButton);
connectButton.setOnClickListener(this);
request_password = (EditText) findViewById(R.id.request_password);
TextView dialog_text = (TextView) findViewById(R.id.dialog_text);
dialog_text.setText("Enter your registered email and request the lost password. You will receive steps to recover your password.");
TextView cancelButton = (TextView) findViewById(R.id.cancelButton);
cancelButton.setOnClickListener(this);
}
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.cancelButton:
dismiss();
break;
case R.id.connectButton:
dismiss();
// Send mail
if (request_password.getText().toString().equals("")) {
request_password.setError("Enter registered Email");
} else {
//Redirect user to Login
if (preferencesManager.getVerificationCode() == null) {
getUserData();
}
}
break;
}
}
/*******************************/
private class SendMailTask extends AsyncTask<String, Void, Void> {
@Override
protected void onPreExecute() {
super.onPreExecute();
progressDialog.show();
}
@Override
protected void onPostExecute(Void aVoid) {
super.onPostExecute(aVoid);
progressDialog.dismiss();
}
@Override
protected Void doInBackground(String... receipt) {
try {
GMailSender sender = new GMailSender("ro-reply@gmail.com", "password");
sender.sendMail("Password Recovery for App title",
receipt[1],
"user@gmail.com",
receipt[0]);
} catch (Exception e) {
Log.d("SendMail", e.getMessage(), e);
}
return null;
}
}
private void getUserData() {
StringRequest jsonAuthenticate = new StringRequest(Request.Method.POST, Config.URL_REQUEST_PASSWORD,
new Response.Listener<String>() {
@Override
public void onResponse(String response) {
if (Constants.DEBUG_MODE_ON)
Log.d(Constants.DEBUG_LOG, "Response for Request Paswword: " + response);
try {
JSONObject result = new JSONObject(response);
JSONArray jcode = result.getJSONArray("code");
JSONObject jCodeObj = jcode.getJSONObject(0);
int code = jCodeObj.getInt("code");
if (code == 1) {
} else {
progressDialog.dismiss();
Toast.makeText(c, "No such email is registered.", Toast.LENGTH_SHORT).show();
}
} catch (Exception e) {
progressDialog.dismiss();
Log.d(Constants.DEBUG_LOG, "Volley Exception: " + e.getCause() + " -> " + e.toString());
e.printStackTrace();
}
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Toast.makeText(c, "Oh! Something went wrong. Please try again.", Toast.LENGTH_SHORT).show();
progressDialog.dismiss();
Log.d(Constants.DEBUG_LOG, "Error Response : " + error.toString() + " MESSAGE: " + error.getMessage() + " CAUSE:" + error.getCause());
}
}) {
@Override
protected Map<String, String> getParams() {
Map<String, String> params = new HashMap<String, String>();
params.put("email", request_password.getText().toString());
return params;
}
};
jsonAuthenticate.setRetryPolicy(new RetryPolicy() {
@Override
public int getCurrentTimeout() {
return 10000;
}
@Override
public int getCurrentRetryCount() {
return 2;
}
@Override
public void retry(VolleyError error) throws VolleyError {
}
});
MyApplication.getInstance().addToReqQueue(jsonAuthenticate);
}
注意:您必须为此使用 GmailLSender...
import javax.activation.DataHandler;
import javax.activation.DataSource;
import javax.mail.Message;
import javax.mail.PasswordAuthentication;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.security.Security;
import java.util.Properties;
public class GMailSender extends javax.mail.Authenticator {
private String mailhost = "smtp.gmail.com";
private String user;
private String password;
private Session session;
static {
Security.addProvider(new JSSEProvider());
}
public GMailSender(String user, String password) {
this.user = user;
this.password = password;
Properties props = new Properties();
props.setProperty("mail.transport.protocol", "smtp");
props.setProperty("mail.host", mailhost);
props.put("mail.smtp.auth", "true");
props.put("mail.smtp.port", "465");
props.put("mail.smtp.socketFactory.port", "465");
props.put("mail.smtp.socketFactory.class",
"javax.net.ssl.SSLSocketFactory");
props.put("mail.smtp.socketFactory.fallback", "false");
props.setProperty("mail.smtp.quitwait", "false");
session = Session.getDefaultInstance(props, this);
}
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(user, password);
}
public synchronized void sendMail(String subject, String body, String sender, String recipients) throws Exception {
try{
MimeMessage message = new MimeMessage(session);
DataHandler handler = new DataHandler(new ByteArrayDataSource(body.getBytes(), "text/plain"));
message.setSender(new InternetAddress(sender));
message.setSubject(subject);
message.setDataHandler(handler);
if (recipients.indexOf(',') > 0)
message.setRecipients(Message.RecipientType.TO, InternetAddress.parse(recipients));
else
message.setRecipient(Message.RecipientType.TO, new InternetAddress(recipients));
Transport.send(message);
}catch(Exception e){
}
}
public class ByteArrayDataSource implements DataSource {
private byte[] data;
private String type;
public ByteArrayDataSource(byte[] data, String type) {
super();
this.data = data;
this.type = type;
}
public ByteArrayDataSource(byte[] data) {
super();
this.data = data;
}
public void setType(String type) {
this.type = type;
}
public String getContentType() {
if (type == null)
return "application/octet-stream";
else
return type;
}
public InputStream getInputStream() throws IOException {
return new ByteArrayInputStream(data);
}
public String getName() {
return "ByteArrayDataSource";
}
public OutputStream getOutputStream() throws IOException {
throw new IOException("Not Supported");
}
}
}
关于java - 注册安卓应用后发送验证邮件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33858608/
我有一个问题,想知道如何在已经使用常规登录/注册系统的网站上集成第 3 方登录(也进行静默注册)。 基本上当前登录还是比较规律的: 当用户进入网站 session 时类(class)决定他是否需要重新
我在学习 Hyperledger Fabric 并运行示例代码。 我仍在尝试正确了解事情的运作方式,尤其是在使用证书和加密 Material 的用户/管理员注册和注册中。 我想知道以下如何工作。 1)
我正在尝试使用从我的 Android 设备的 PassWallet 应用程序中保存的票证中获取的 token 向我的设备发送消息。 设备发送使用苹果钱包规范更新通行证所需的所有信息。但是,我正在使用
使用 Passport 本地示例,我可以登录工作。没有关于如何注册用户的文档。 我想为用户提供一个“电子邮件”和“密码”字段,他们可以使用它们来注册该网站。我怎样才能做到这一点?有什么原因没有记录下来
在之前的一些 WSO2IS 版本中,有一个默认的 self 注册功能。但是,我在 5.0 版本中找不到它。 阅读 WSO2IS 5.0 文档,我发现有 2 个用于此功能的 API: getUserId
我已将 Airship SDK 集成到 Android 应用程序中。在应用程序启动和飞艇起飞后,我在日志中得到以下调试信息: 07-27 12:46:31.916 XXX - UALib( 1545)
Delphi 中设计时包的可怕错误之一是以下错误,这意味着注册安装新组件到您的 Palette 上的包: Component TSomething can't be registered by pac
我发现的大部分内容都使用 php 或类似的东西。 我有一个 Angular 前端和 Node/express 服务器代码。还没有后端。我不确定如何继续用户注册。 最佳答案 在没有后端的情况下进行注册等
我正在使用 Drupal 6 开发一个网站。我正在使用我自己的主题,并且一切正常。现在我需要使用我的自定义主题在我的网站上创建一个自定义登录/注册表单。我尝试了很多方法,但一切都重定向到我的管理主题,
我在运行此代码时收到 Sip 异常。这是因为 manager.register(me,20,listener)。 下面是我的代码,所以请帮我更正这段代码。我正在使用 SipDemo 代码注册我的帐户。
在过去的几天里,我一直在尝试为基于 VUE 的 excel 制作任务 Pane 插件。 我已按照 link 的指南进行操作我试图为 onSelectionChange 注册一个事件处理程序。它已经有些
我需要在使用 django-registration 应用程序的登录表单中实现一个“记住我”按钮。任何ane可以帮助我向我展示这样做的方法吗? 谢谢 最佳答案 一种方法是更改 session 到期
我发现,如果您使用 Django 1.5 版本,则 django 注册模块会中断,因为在最新的 django 开发版本中,simple.py 类已被删除。 最佳答案 此问题现已修复: hg clone
我正在尝试将 facebook connect 实现到我的网站,但有几个问题。 1:是否可以使用用户当前的 Facebook 电子邮件/密码在我的网站上注册用户。 假设用户点击链接通过 faceboo
我使用 Facebook 注册来允许人们在我的网站上注册。有没有可能,在注册后,他在我的网站注册的成员(member)墙上会张贴? 最佳答案 这可能不是您正在寻找的答案,但我强烈建议您不要这样做。用户
I would like to use a slash (/) for a search during a vimscript, but I don't want to overwrite the "
我正在使用 jqgrid 并且有显示日期的列,但是来自服务器的日期以 json 格式出现,如下所示, "CommentedDate": "\/Date(1304324941000+0530)\/" 如
我希望用户可以直接登录主页,而不是在“../account/login/”页面上登录。我应该做什么才能使它成为可能?如何将主页上的输入字段与 allauth 连接?我不知道这样是否太复杂而无法以这种方
This question already has answers here: Understanding NSString comparison (7个答案) 5年前关闭。 我正在尝试制作注册表。有
我正在使用 Django 注册。它提供了处理 registration_form.html 的 View ,该 html 当前包含用户名、密码 1、密码 2 和电子邮件作为我的应用程序中的用户可输入字
我是一名优秀的程序员,十分优秀!