BugTracker部署好之后,发现增加bug不能mail提醒。于是补上这个功能记录在此,方法是次要的,主要是找到地方。需要3步。吐槽下Asp的代码风格看的真心蛋疼....

一、发送mail(主要是找到位置)

1.在App_Code中加入MailHelper.cs .

using System;
using System.Net.Mail; public class MailHelper
{
/// <summary>
/// 异步发送邮件
/// </summary>
/// <param name="toMails"></param>
/// <param name="subject"></param>
/// <param name="content"></param>
public static void SystemSendMail(string toMails, string subject, string content)
{ Action invokeAction = () => WebMailTo(toMails, subject, content);
invokeAction.BeginInvoke(Callback, invokeAction); } private static void Callback(IAsyncResult ar)
{
var action = ar.AsyncState as Action;
if (action != null) action.EndInvoke(ar);
} /// <summary>
/// Webs the mail to.
/// </summary>
/// <param name="toEmails">To emails.</param>
/// <param name="subject">The subject.</param>
/// <param name="emailText">The email text.</param>
/// <returns><c>true</c> if XXXX, <c>false</c> otherwise</returns>
public static bool WebMailTo(string toEmails, string subject, string emailText)
{
#region 此处参数使用时根据需要替换成自己的
const string server = "172.17.xxx.95"; //此处代表Mail Server地址
const string formEmail = xxxxx.xxx@xxx.com.cn"; //此处代表系统发邮件的时候的发件人地址
const string formDispayName = "BugTracker"; //系统发件人的显示名称
const string formPassword = "xxxxx"; //此处代表系统发邮件的时候的发件人的密码
const string formDomain = "xxxwj"; //域名
#endregion const string systermtxt = "<br/>该邮件为系统自动发送,请勿回复!详情请点击" + "<a href='http://cnwj6iapc016:84/'>这里~</a>";
var mailMessage = new MailMessage { IsBodyHtml = true };
mailMessage.To.Add(toEmails);
mailMessage.From = new MailAddress(formEmail, formDispayName);
mailMessage.Subject = subject;
mailMessage.Body = emailText + systermtxt;//此处可以传递一个html
mailMessage.Priority = MailPriority.High;
var client = new SmtpClient
{
Host = server,
UseDefaultCredentials = false,
Credentials = new System.Net.NetworkCredential(formEmail, formPassword, formDomain),
DeliveryMethod = SmtpDeliveryMethod.Network,
EnableSsl = false
};
bool isSendOk;
try
{
client.Send(mailMessage);//发送Mail
isSendOk = true; }
catch (Exception)
{ isSendOk = false;
}
return isSendOk;
}
}

2.给在App_Code的dbutil.cs加入个功能函数。

  public static string GetStringById(int id,StringType stringType)
{
using (SqlConnection conn = get_sqlconnection())
{
var sql = "";
switch (stringType)
{
case StringType.Email:
sql = "select us_email from users where us_id=" + id;
break;
case StringType.ProjectDefaultUserId:
sql = "select pj_default_user from projects where pj_id=" + id;
break;
case StringType.UserName:
sql = "select us_username from users where us_id=" + id;
break;
}
DataSet ds = new DataSet();
SqlDataAdapter da = new SqlDataAdapter(sql, conn);
int c = da.Fill(ds, "table");
DataRow[] dr = ds.Tables[].Select();
conn.Close();
return c != ? dr[][].ToString() : "";
}
} public enum StringType
{
Email,
ProjectDefaultUserId,
UserName
}

3.在App_Code的bug.cs中修改insert_bug 方法。

 sql = sql.Replace("$short_desc", short_desc.Replace("'", "''"));
sql = sql.Replace("$tags", tags.Replace("'", "''"));
sql = sql.Replace("$reported_user", Convert.ToString(security.user.usid));
sql = sql.Replace("$project", Convert.ToString(projectid));
sql = sql.Replace("$org", Convert.ToString(orgid));
sql = sql.Replace("$category", Convert.ToString(categoryid));
sql = sql.Replace("$priority", Convert.ToString(priorityid));
sql = sql.Replace("$status", Convert.ToString(statusid));
sql = sql.Replace("$assigned_user", Convert.ToString(assigned_to_userid));
sql = sql.Replace("$udf", Convert.ToString(udfid));
sql = sql.Replace("$pcd1", project_custom_dropdown_value1);
sql = sql.Replace("$pcd2", project_custom_dropdown_value2);
sql = sql.Replace("$pcd3", project_custom_dropdown_value3); // 发送mail 这里才是补充的代码。
var str = string.Format("<div style='padding:20px;border:2px solid green'>{0}维护了与你相关的新的Bug,详细情况请登录Bug管理系统</div>", security.user.username);
var pid = DbUtil.GetStringById(projectid, StringType.ProjectDefaultUserId);
if (pid == "")
{
pid = "";
}
var defaultuserid = Convert.ToInt16(pid);
if (defaultuserid != )
{
MailHelper.SystemSendMail(DbUtil.GetStringById(defaultuserid, StringType.Email), "BugTracker:你有新的bug了", str);
}
if (defaultuserid != assigned_to_userid)
{
MailHelper.SystemSendMail(DbUtil.GetStringById(assigned_to_userid, StringType.Email), "BugTracker:你有新的bug了", str);
}

这样子就ok了。增加不过的时候,会发送给抄送人和工程负责人。

同理,如果要在评论更显得 时候也加入mail通知。评论对应的数据库中的表是bug_posts. 插入的方法在App_Code/bug.cs中的

public static int insert_comment(.....) 方法中。

在return之前加入下面的代码:

sql = sql.Replace("$cc", cc.Replace("'", "''"));
sql = sql.Replace("$internal", btnet.Util.bool_to_string(internal_only)); DataRow[] drs = DbUtil.GetBugDataRows(bugid);
if (drs.Count() != )
{
var buguserId = Convert.ToInt16(drs[]["bg_reported_user"]);// 发布bug的人
var bugassigneduserId = Convert.ToInt16(drs[]["bg_assigned_to_user"]);//bug抄送的人
var projectId = Convert.ToInt16(drs[]["bg_project"]);
const string titile = "Bug有新的评论";
var bugdesc = drs[]["bg_short_desc"].ToString();
var content = string.Format("<div style='padding:20px;border:3px solid blueviolet;'>Bug {0}(Id :{1})有新的评论:<br/><p style='color:gray;font-size:small;background: #ffffe0'>{2}</p></div>", bugdesc, bugid, comment_formated.Replace("'", "''"));
if (this_usid != buguserId)//避免是同一人 而重复发送。
{
MailHelper.SystemSendMail(DbUtil.GetStringById(buguserId,StringType.Email),titile,content);
}
if (bugassigneduserId != && this_usid != bugassigneduserId)//避免是同一人 而重复发送。
{
MailHelper.SystemSendMail(DbUtil.GetStringById(bugassigneduserId, StringType.Email), titile, content);
} if (projectId != )
{
var pduid =Convert.ToInt16(DbUtil.GetStringById(projectId, StringType.ProjectDefaultUserId)) ;
if (pduid != && this_usid != pduid && pduid != bugassigneduserId)//避免是同一人 而重复发送。
{
MailHelper.SystemSendMail(DbUtil.GetStringById(pduid, StringType.Email), titile, content);
}
} }

另外需要在dbutil.cs中加入一些方法

public static string GetStringById(int id,StringType stringType)
{
using (SqlConnection conn = get_sqlconnection())
{
var sql = "";
switch (stringType)
{
case StringType.Email:
sql = "select us_email from users where us_id=" + id;
break;
case StringType.ProjectDefaultUserId:
sql = "select pj_default_user from projects where pj_id=" + id;
break;
case StringType.BugUserId:
sql = "select bg_reported_user from bugs where bg_id=" + id;
break;
}
var ds = new DataSet();
var da = new SqlDataAdapter(sql, conn);
var c = da.Fill(ds, "table");
var dr = ds.Tables[].Select();
conn.Close();
return c != ? dr[][].ToString() : "";
}
} public static DataRow[] GetBugDataRows(int bugId)
{
using (SqlConnection conn = get_sqlconnection())
{
var sql = "select * from bugs where bg_id=" + bugId;
var ds = new DataSet();
var da = new SqlDataAdapter(sql, conn);
da.Fill(ds, "table");
var drs=ds.Tables[].Select();
conn.Close();
return drs;
}
}

最后效果:

二、自动登录

自动登录也要改改,每次都要点一次。刚开始以为在login打头的文件中,试了几次登录函数是在default.aspx 页面中。

1、在Page_Load中的 if (username_cookie != null) 中加入最后三句,就是判断下cookie。asp中的控件赋值比较神器.... input元素直接可以点出value。

if (username_cookie != null)
{
// Set the user name from the last logon.
user.Value = username_cookie["name"];
var pcookie = Request.Cookies["pwd"];
if (pcookie != null && pcookie.Value!="")
{
pw.Value = pcookie.Value;
on_logon();
}
}

2、再在下面的on_logon() 中的 if (authenticated) 中加入下面的代码。 初始的时候加上cookie

var httpCookie = Response.Cookies["pwd"];
if (httpCookie == null)
{
var currentCookie = new HttpCookie("pwd") {Value = pw.Value, Expires = DateTime.Now.AddDays()};
Response.Cookies.Add(currentCookie);
}
else
{
httpCookie.Value = pw.Value;
}

3、处理退出,不然的话人家登录了很难切换用户。

用户点击右上角的logoff的时候,其实是先跳转到了logoff.aspx页面。在页面跳转到defau.aspx之前,清空cookie的值。

 var httpCookie = Response.Cookies["pwd"];
if (httpCookie != null)
{
httpCookie.Value = null;
} Response.Redirect("default.aspx?msg=logged+off");

感觉下次就会用上。

BugTracker 加入发Mail的功能的更多相关文章

  1. django自带的django.core.mail模块实现发邮件的功能

    django自带了一个模块,可以实现发邮件的功能.如果项目开发遇到需要发邮件进行验证的时候可以用到. 1.先要准备发件人 发邮件需要使用SMTP.SMTP是什么呢? 简单邮件传输协议(Simple M ...

  2. Post方法调用公司发Mail的接口

    调用公司发Mail的接口. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http ...

  3. MOSS程序中如何发Mail?

    我们使用.NET类库中的API发Mail的时候,我们要配置他的SMTP Server等,但是在Sharepoint里,已经提供了相关的封装的方法: SPUtility.SendEmail(SPWeb, ...

  4. 用JS实现发邮件的功能 完美解决

    怎样用JS实现发邮件的功能? 我想用JS实现把页面文本框中的内容直接通过邮件的方式发送到一个指定的邮箱.fengxq给出的答案是<script language=javascript>if ...

  5. 客户注册功能,发短信功能分离 通过ActiveMQ实现

    客户注册功能,发短信功能分离 通过ActiveMQ 配置链接工厂, 配置session缓存工厂(引入链接工厂) 2.配置模板对象JmsTemplate 引入缓存工厂    指定消息模式(队列,发布和订 ...

  6. 项目一:在线下单(补充) activeMQ使用(重点) 重构客户注册功能,发短信功能分离

    1 课程计划 1.在线下单(补充) 2.activeMQ使用(重点) n 简介和安装 n activeMQ入门案例 n spring整合activeMQ应用 3.重构客户注册功能,发短信功能分离 n  ...

  7. html5开发手机打电话发短信功能

    原文:http://www.open-open.com/code/view/1449843459332 在很多的手机网站上,有打电话和发短信的功能,对于这些功能是如何实现的呢.其实不难,今天我们就用h ...

  8. html5开发手机打电话发短信功能,html5的高级开发,html5开发大全,html手机电话短信功能具体解释

    在非常多的手机站点上,有打电话和发短信的功能,对于这些功能是怎样实现的呢.事实上不难,今天我们就用html5来实现他们. 简单的让你大开眼界.HTML5 非常easy写,但创建网页时,您常常须要反复做 ...

  9. java实现发短信功能---腾讯云短信

    目录 java实现发短信功能 前言 开发环境 腾讯云 ---短信 代码 效果 结束语 java实现发短信功能 前言 如今发短信功能已经成为互联网公司的标配,本篇文章将一步步实现java发送短信 考察了 ...

随机推荐

  1. bat脚本命令循环运行程序 ,然后指定时间退出。

    @echo offtitle EcCheck // 显示标题:loopif "%time%" GTR "23:00.00" (exit) else goto t ...

  2. 内置对象(Session、Application、ViewState)

    内置对象:为了跨页面传值和状态保持.→HTTP的无状态性 [4.]Session:每一台电脑访问服务器,都会是独立的一套session,key值都一样,但是内容都是不一样的 以上所有内容,都跟cook ...

  3. Asp.Net 获取FileUpload控件的文件路径、文件名、扩展名

    string fileNameNo = Path.GetFileName(FileUploadImg.PostedFile.FileName); //获取文件名和扩展名string Directory ...

  4. linux 下文件节点索引

    最近发现一个奇怪的问题,就是一个pyhton 后台的服务一直打印日志文件,在中间我用vim看日志文件,关闭时习惯性的:wq退出,在此之后日志文件就不输出了. 1 对于这个现象我开始认为是python ...

  5. Aborting commit: 'XXX' remains in conflict

    Aborting commit: 'XXX' remains in conflict 错误   本地也删除了一个文件夹,用svn 的repo-brower 删除了服务器上的对应的文件夹 ,再次comm ...

  6. Gradle Android Studio basic

    1. change gradle version in gradle/wrapper/gradle-wrapper.properties  change distributionUrl=http\:/ ...

  7. Jquery 生成时钟

    $(function(){ showTime(); }): function showTime () { var curtime=new Date(); $(".getDateTime&qu ...

  8. 违反并发性: UpdateCommand影响了预期 1 条记录中的 0

    今天遇到这个错误,看到下面这种说法都没解决问题: 1 检查是否设有主键.2 DeleteCommand的问题:检查是否含有自动编号字段(Access的自动编号字段可能会引发此异常):  UpdateC ...

  9. 5.HotSpot的算法实现

    1.枚举根节点 在可达性分析中,可以作为GC Roots的节点有很多,但是现在很多应用仅仅方法区就有上百MB,如果逐个检查的话,效率就会变得不可接受. 而且,可达性分析必须在一个一致性的快照中进行-即 ...

  10. PLSQL数据导入导出问题解决(空表、大字段表、表空间错误等)

    PLSQL使用方法简单,平常使用较多,但在平常使用过程中,遇到一些问题,下面简单罗列并进行解决.这些解决方法大多通过网络查找获得,这里只是进行简单整理. 使用的数据库版本为:Oracle11g. 通用 ...