庆祝s

或多或少
数据加载中……

2009年2月12日

trigger

alter trigger trig_forguangligonghao
on sys_flowinfo
for insert
as
declare @docid varchar(100),@flowid varchar(100),@stepnum int,
@sfnjsdy varchar(50),@sqlb varchar(100)
select @docid=DocID,@flowid=FlowID,@stepnum=StepNum from inserted
if @stepnum = 2
begin
 select @sfnjsdy=sfnjsdy,@sqlb=sqlb from ghqxapply where fid=@docid
 if @sfnjsdy = '否' or @sqlb like '%修改角色权限%'
 begin
  print @stepnum
  update sys_flowinfo set NextAboutNoteName = '市场部业务主管审核;',AboutDirectionName = '送市场部业务主管审核;'
 
  where (DocID = @docid) and (FlowID = @flowid) and (StepNum = @stepnum)
 end
end

posted @ 2009-02-12 17:15 庆祝 阅读(22) 评论(0) 编辑

2008年9月5日

来源于:鹰翔宇空的文章

今天在研究javamail发信的过程中,出现了一些小问题,现总结如下,以免后来者走些不必要的弯路,先把完整的能够正常运行的代码示例粘贴如下:
发邮件源代码:
package com.hyq.test;

import java.util.Properties;
import javax.mail.*;
import javax.mail.internet.*;

public class MailExample {

  public static void main (String args[]) throws Exception {
   
    String host = "smtp.163.com";   //发件人使用发邮件的电子信箱服务器
    String from = "你自己的电子信箱";    //发邮件的出发地(发件人的信箱)
    String to = "收件人信箱";   //发邮件的目的地(收件人信箱)

    // Get system properties
    Properties props = System.getProperties();

    // Setup mail server
    props.put("mail.smtp.host", host);

    // Get session
    props.put("mail.smtp.auth", "true"); //这样才能通过验证

    MyAuthenticator myauth = new MyAuthenticator("你自己的电子信箱", "你自己的信箱密码");
    Session session = Session.getDefaultInstance(props, myauth);

//    session.setDebug(true);

    // Define message
    MimeMessage message = new MimeMessage(session);
   

    // Set the from address
    message.setFrom(new InternetAddress(from));

    // Set the to address
    message.addRecipient(Message.RecipientType.TO,
      new InternetAddress(to));

    // Set the subject
    message.setSubject("测试程序!");

    // Set the content
    message.setText("这是用java写的发送电子邮件的测试程序!");

    message.saveChanges();

      Transport.send(message);
    
  }
}

校验发信人权限的方法
package com.hyq.test;

import javax.mail.PasswordAuthentication;

class MyAuthenticator
      extends javax.mail.Authenticator {
    private String strUser;
    private String strPwd;
    public MyAuthenticator(String user, String password) {
      this.strUser = user;
      this.strPwd = password;
    }

    protected PasswordAuthentication getPasswordAuthentication() {
      return new PasswordAuthentication(strUser, strPwd);
    }
  }


注 意:上面的事例仅为使用163信箱时发送电子邮件的方法,因为使用的host为:smtp.163.com,如源代码中:String host = "smtp.163.com";   //发件人使用发邮件的电子信箱服务器,如果使用其它的电子邮件发送,就必须在其邮件服务器上查找相应的电子邮件服务器,例如搜狐就要使用 smtp.sohu.com,具体情况具体对待,都可以从所使用的邮件服务器上获得的。如果没有使用host ,也就是说,没有进行props.put("mail.smtp.host", host);设置,那么就会抛javax.mail.MessagingException: Could not connect to SMTP host: localhost, port: 25;的异常。当然了,如果你没有正确配置,这个异常仍然会被抛出的。

有些邮件服务系统是不需要验证发件人的授权的,所以可以很简单的使用
    Session session = Session.getDefaultInstance(props, null);
             而不必使用
    props.put("mail.smtp.auth", "true"); 
    MyAuthenticator myauth = new MyAuthenticator("你自己的电子信箱", "你自己的信箱密码");
    Session session = Session.getDefaultInstance(props, myauth);

就可以发送电子邮件了,这个多为一些企事业单位的内部电子信箱系统。
但是对于很多门户网站上的电邮系统,如:163,sohu,yahoo等等,如果仍然简单的这样使用就会抛

com.sun.mail.smtp.SMTPSendFailedException: 553 authentication is required,smtp8,wKjADxuAyCAfmnZE8BwtIA==.32705S2


 at com.sun.mail.smtp.SMTPTransport.issueSendCommand(SMTPTransport.java:1388)

 at com.sun.mail.smtp.SMTPTransport.mailFrom(SMTPTransport.java:959)

 at com.sun.mail.smtp.SMTPTransport.sendMessage(SMTPTransport.java:583)

 at javax.mail.Transport.send0(Transport.java:169)

 at javax.mail.Transport.send(Transport.java:98)

这样的异常,要求你必须进行授权校验,它的目的就是阻止他人任意乱发邮件,也算是为了减少垃圾邮件的出现吧。这时候,我们就要使用
    props.put("mail.smtp.auth", "true"); 
    MyAuthenticator myauth = new MyAuthenticator("你自己的电子信箱", "你自己的信箱密码");
    Session session = Session.getDefaultInstance(props, myauth);

这 里还有一个特别注意的事情:在你使用Session.getDefaultInstance时,一定要将    props.put("mail.smtp.auth", "true"); 置为true,它默认的是false,如果你没有做这一步,虽然你使用了 Session.getDefaultInstance(props, myauth);,你自己也确实    MyAuthenticator myauth = new MyAuthenticator("你自己的电子信箱", "你自己的信箱密码");但是它仍然会抛出
com.sun.mail.smtp.SMTPSendFailedException: 553 authentication is required,smtp8,wKjADxJA2SBrm3ZEFv0gIA==.40815S2


 at com.sun.mail.smtp.SMTPTransport.issueSendCommand(SMTPTransport.java:1388)

 at com.sun.mail.smtp.SMTPTransport.mailFrom(SMTPTransport.java:959)

 at com.sun.mail.smtp.SMTPTransport.sendMessage(SMTPTransport.java:583)

 at javax.mail.Transport.send0(Transport.java:169)

 at javax.mail.Transport.send(Transport.java:98)
这样的异常。我就在这一步费了好长时间,后来才发现了这个问题,很是郁闷。不过还好,总算解决了。

其实上面的做法只是比较简单的一种,也有很多其它的写法,如:
Properties props = System.getProperties();可以使用
Properties props = new Properties();来代替。

Transport.send(message);可以使用下面的代码来代替
      String username = "你的电子信箱用户名";
      String password = "你的电子信箱密码";
      message.saveChanges(); //    implicit with send()
      Transport transport = session.getTransport("smtp");
      transport.connect("mail.htf.com.cn", username, password);
      transport.sendMessage(message, message.getAllRecipients());
      transport.close();
这种方法在同时发送多封电子邮件时比较有用。

还有一些具体的相关概念,可以查看相关的官方文档,在我查询资料时,发现了一篇文章写得相当仔细,可以加以参考:http://www.matrix.org.cn/resource/article/44/44101_JavaMail.html

另附上使用org.apache.commons.mail进行发电子邮件的示例:
import org.apache.commons.mail.SimpleEmail;
import org.apache.commons.mail.*;

public class TestCommon {
  public TestCommon() {
  }
  public static void main(String[] args){
    SimpleEmail email = new SimpleEmail();
    email.setHostName("smtp.163.com");//设置使用发电子邮件的邮件服务器
    try {
      email.addTo("收件人信箱");
      email.setAuthentication("发件人信箱","发件人信箱密码");
      email.setFrom("发件人信箱");
      email.setSubject("Test apache.commons.mail message");
      email.setMsg("This is a simple test of commons-email");
      email.send();
    }
    catch (EmailException ex) {
      ex.printStackTrace();
    }
  }
}

posted @ 2008-09-05 11:12 庆祝 阅读(78) 评论(0) 编辑

2008年8月27日

动态判断性别选中的问题

</html>

PS 一定要写在 </html>后面

<script type="text/javascript" language="javascript">
    var sex = '${staff.sex}';
        if(sex=="男")
        {
           document.getElementsByName("sex")[0].checked=true;  
        }else{
           document.getElementsByName("sex")[1].checked=true;  
        }
</script>

posted @ 2008-08-27 12:32 庆祝 阅读(27) 评论(0) 编辑

2008年8月17日

来在表格中换行

在JAVA WEB的MVC架构里

V是代表视图层的

一般不要用太多的<%  .......%>标签

会给美工人员带来或多或少的麻烦

 

所以就使用的 下面的带码来让便利出来的东西 在表格里换行

<table cellspacing="10" width="100%" border="0" bordercolor="#f0f0f0">
<tr>
<c:forEach items="${requestScope.productlist}" var="product" varStatus="i">
<td valign="top">
<a href="productinfo.do?id=${product.productid}" >${product.productname}</a>
<br/>
<a href="productinfo.do?id=${product.productid}" ><img src="${product.img}" alt="" width="200"/></a>
<br/>
<font color="red" size="-1">¥${product.sellprice}</font>
</td>
<c:if test="${i.count % 3==0}"></tr></c:if>
</c:forEach>
<table>

PS 关键的代码是<c:foreach 中的varstatus 中定义的i>

i.count 它是固定的相当于i++


posted @ 2008-08-17 16:02 庆祝 阅读(212) 评论(0) 编辑

2008年8月7日

JDK的配置

我的电脑->属性->高级->环境变量->系统变量中添加以下环境变量:

JAVA_HOME=C:\j2sdk1.4.2_04
CLASSPATH=.;C:\j2sdk1.4.2_04\lib\tools.jar;C:\j2sdk1.4.2_04\lib\dt.jar;C:\j2sdk1.4.2_04\bin;
path=C:\j2sdk1.4.2_04\bin;

posted @ 2008-08-07 11:29 庆祝 阅读(15) 评论(0) 编辑

2008年6月15日

把struts验证框架的模板翻译成了中文

posted @ 2008-06-15 09:02 庆祝 阅读(121) 评论(1) 编辑

2008年6月14日

常用的表查询MSSQL语句

posted @ 2008-06-14 10:49 庆祝 阅读(30) 评论(0) 编辑

2008年6月13日

利用JavaEE的Validator

posted @ 2008-06-13 20:54 庆祝 阅读(29) 评论(0) 编辑

2008年5月15日

可以创建xml的JAVA工厂类--------JAVA

posted @ 2008-05-15 09:11 庆祝 阅读(445) 评论(0) 编辑

2008年5月7日

Html简单的Head区专业知识

posted @ 2008-05-07 22:08 庆祝 阅读(23) 评论(0) 编辑