Deprecated: Creation of dynamic property Kirki\Field\Repeater::$compiler is deprecated in /home1/diywmcom/public_html/baifaqimei/wp-content/themes/blogstream/functions/kirki/kirki-packages/compatibility/src/Field.php on line 305
积累┊技术 – 白发齐眉

积累┊技术

使用Agent转发Lotus邮件

经发现,直接复制粘贴本文内容过去,导致双引号和单引号有问题,因此会有代码出错,建议粘贴过去前,先将”和’检查下,将lotus里粘贴过来的所有双引号和单引号用”和’替换一遍即可。否则会有红色字提示代码出错。

我在文末也附上txt档的文本,里面的双引号和单引号是对的。可以粘贴txt文档里的代码,点此下载1.

1.

首先,新建一个Agent,其Runtime这里的属性选择为on event,after new mail has arrived。如下图。

2.

Declarations里,定义如下变量,

TargetEmail改成你自己需要转发的Email

Const TargetEmail = “XXX@xxx.com”
Dim db As notesdatabase
Dim session As NotesSession

3.
在Initialize那里,输入如下的代码:
Sub Initialize
Dim doc As NotesDocument
Dim ReturnVal As Boolean
Dim PojistkaMax As Integer
Dim collection As NotesDocumentCollection
Dim Addeditem As NotesItem
Dim CurAgent As NotesAgent
Dim docStatus As Variant
Dim docProcessed As Boolean
Set session = New NotesSession
Set db = session.CurrentDatabase
Set CurAgent = session.CurrentAgent
PojistkaMax = 0
Set collection = db.UnprocessedDocuments
Set doc = collection.GetFirstDocument()
While Not(doc Is Nothing Or PojistkaMax>20)
docStatus=””
docProcessed = False
If (Doc.HasItem(CurAgent.Name & “_done”)) Then
docStatus = Doc.GetItemValue(CurAgent.Name & “_done”)
If (Cstr(docStatus(0))=”1″) Then docProcessed=True
End If
If (docProcessed=False) Then
Call ProcessEmail (doc)
If (Doc.HasItem(CurAgent.Name & “_done”)) Then
Call doc.ReplaceItemValue(CurAgent.Name & “_done”,”1″)
Call doc.Save( True, False, False )
Else
Set Addeditem = doc.AppendItemValue ( CurAgent.Name & “_done”, “1” )
Call doc.Save( True, False, False )
End If
End If
Call session.UpdateProcessedDoc(doc)
Set doc = collection.GetNextDocument(doc)
PojistkaMax = PojistkaMax + 1
Wend
End Sub
Sub ProcessEmail (Mydoc As NotesDocument)
Dim rtnav As NotesRichTextNavigator
Dim MyMssgHeader As String
Dim rtitem As NotesRichTextItem
Dim Maildoc As NotesDocument
Dim senderdomain As String
Dim b As Integer
Dim FromItem As NotesItem
Dim FromName As String
Dim FromEmail As String
Dim FromIDENT As String
Dim FromOrig As String
Dim ItemValue As Variant
Dim m_strForm As String
On Error Goto GenError
If (MyDoc.IsEncrypted) Then Exit Sub
If (myDoc.HasItem(“$KeepPrivate”)) Then
ItemValue = MyDoc.GetItemValue(“$KeepPrivate”)
If (Cstr(ItemValue(0))=”1″) Then Exit Sub
End If
If (Not myDoc.HasItem(“From”)) Then Exit Sub
Set Maildoc = New NotesDocument(db)
Call Mydoc.CopyAllItems( Maildoc, True )
‘        If (Maildoc.HasEmbedded ) Then
Set rtitem = Maildoc.GetFirstItem(“Body”)
‘                  If ( rtitem.Type = RICHTEXT) Then
‘                           If (Not (Isempty(rtitem.EmbeddedObjects))) Then
‘                                    Forall o In rtitem.EmbeddedObjects
‘                                              If ( o.Type = EMBED_ATTACHMENT ) Then
‘                                                       Call o.Remove
‘                                              End If
‘                                    End Forall
‘                           End If
‘                  End If
‘        End If
FromIDENT=””
FromEmail=””
FromName=””
FromOrig=””
If (MailDoc.HasItem(“Principal”)) Then
FromOrig=MailDoc.Principal(0)
Else
FromOrig=MailDoc.From(0)
End If
If (Instr(1,FromOrig,”CN=”)>0 And Instr(1,FromOrig,”OU=”)>0) Then
FromIDENT=FromOrig
Else
Call ParseAddr (FromOrig,FromName, FromEmail)
End If
‘ add by James
If  FromOrig =”Mail Router” Then
Exit Sub
End If
If  FromOrig =”gcsecpoccoord” Then
Exit Sub
End If
If  FromOrig =”LotusQuickr@USSECAVPQUCK02.na.ey.net” Then
Exit Sub
End If
m_strForm = MailDoc.GetItemValue ( “Form”)(0)
If (Strcompare(m_strForm, “Delivery Report”) = 0) Then
Exit Sub
End If
If (Strcompare(m_strForm, “NonDelivery Report”) = 0) Then
Exit Sub
End If
If (Strcompare(m_strForm, “Trace Report”) = 0 ) Then
Exit Sub
End If
If (Strcompare(m_strForm, “Return Receipt”)= 0) Then
Exit Sub
End If
‘ end by James
If (FromIDENT<>””) Then
MailDoc.Principal = FromIDENT
Else
If (FromEmail=””) Then
MailDoc.Principal = FromOrig
Else
MailDoc.Principal = FromName & ” <” & FromEmail & “@NotesDomain” & “>”
MailDoc.INetFrom = FromName & ” <” & FromEmail & “>”
End If
End If
If (Mydoc.HasItem(“ReplyTo”)) Then
Maildoc.ReplyTo = Mydoc.ReplyTo(0)
End If
rtitem.AddNewline(2) ‘ add 2 new lines at the end of Body
rtitem.AppendText(“In the Sent field was: “) ‘ add this text at the end of body, you can modify this part to add this only if in From field is allready something
For b=0 To Ubound(Maildoc.SendTo)
rtitem.AppendText(Maildoc.SendTo(b) + “, “)   ‘add all elements from From field
Next
rtitem.AddNewline(2) ‘ add 2 new lines at the end of Body
rtitem.AppendText(“In the CC field was: “) ‘ add this text at the end of body, you can modify this part to add this only if in CC field is allready something
For b=0 To Ubound(Maildoc.CopyTo)
rtitem.AppendText(Maildoc.CopyTo(b) + “, “)   ‘add all elements from CC field
Next
rtitem.AddNewline(2) ‘ add 2 new lines at the end of Body
rtitem.AppendText(“In the BCC field was: “) ‘ add this text at the end of body, you can modify this part to add this only if in CC field is allready something
For b=0 To Ubound(Maildoc.BlindCopyTo)
rtitem.AppendText(Maildoc.BlindCopyTo(b) + “, “)   ‘add all elements from CC field
Next
If (Maildoc.HasItem(“CopyTo”)) Then
Maildoc.CopyTo = “”
End If
If (Maildoc.HasItem(“BlindCopyTo”)) Then
Maildoc.BlindCopyTo = “”
End If
Maildoc.SendTo = TargetEmail
Call Maildoc.Send(False)
Set Maildoc = Nothing
Exit Sub
GenError:
Set Maildoc=Nothing
Set Maildoc = New NotesDocument(db)
With Maildoc
.Subject=”An error occured while parsing”
.SendTo = TargetEmail
.Body=”An error occured while parsing message ”         & Mydoc.Subject(0) & “, from: ” & Mydoc.From(0) & “….Err msg: ” & Error$
Call .Send(False)
End With
Set Maildoc=Nothing
Exit Sub
End Sub
Sub ParseAddr (ParseWhat As String, Part1 As String,Part2 As String)
Dim i As Integer
Dim i2 As Integer
i=Instr(1,ParseWhat,”<“)
i2=Instr(i,ParseWhat,”>”)
If (i>=i2) Then
Exit Sub
End If
If (i=0) Then i=0
If (i2=0) Then i2=Len(ParseWhat)+1
If (i>=3) Then
Part1=Mid(ParseWhat,1,i-2)
End If
Part2=Mid(ParseWhat,i+1,i2-i-1)
If (Instr(1,Part2,”@”)=0) Then
Part2=””
End If
End Sub
之后,系统会自动帮你分割成如下的图:
4.
确认Terminate那边有如下的语句:
Sub Terminate
End Sub
以上是通过Agent转发邮件的一个方法,已经考虑到了大部分的死循环问题,但不保证100%不会发生。本人编程水平有限。
以上资料供各位学习编程知识使用,请根据公司邮件要求/规则适当使用,本人不对使用上述代码所造成的损失负责。

PJblog与Msn spaces同步更新方法

在研究了下cdo.message组件和jmail组件之后,尝试了下,发现jmail容易乱码,而cdo.message却不大会发生乱码现象。

为了让msn spaces能够通过邮件发送生成日志,
首先,进入msn spaces下,“选项”-“邮件发布”,下开启邮件发布功能,并且选择“立即发布”。这样你将得到一个有密文的邮件地址,这个就是将来的日志收件人,假设为rain518.xxx@spaces.live.com
其次,新建一个空白asp文件,其内容为

[code]

<% public Function Send(strTitle,strBriefBody) On Error Resume Next SendMail="#err" err.Clear Const cdoSendUsingMethod="http://schemas.microsoft.com/cdo/configuration/sendusing" Const cdoSendUsingPort=2 Const cdoSMTPServer="http://schemas.microsoft.com/cdo/configuration/smtpserver" Const cdoSMTPServerPort="http://schemas.microsoft.com/cdo/configuration/smtpserverport" Const cdoSMTPConnectionTimeout="http://schemas.microsoft.com/cdo/configuration/smtpconnectiontimeout" Const cdoSMTPAuthenticate="http://schemas.microsoft.com/cdo/configuration/smtpauthenticate" Const cdoSMTPEncoding="http://schemas.microsoft.com/cdo/configuration/languagecode" Const cdoBasic=1 Const cdoSendUserName="http://schemas.microsoft.com/cdo/configuration/sendusername" Const cdoSendPassword="http://schemas.microsoft.com/cdo/configuration/sendpassword" Dim objConfig ' As CDO.Configuration Dim objMessage ' As CDO.Message Dim Fields ' As ADODB.Fields strBriefBody1=strBriefBody strTitle1=strTitle1 Set objConfig = Server.CreateObject("CDO.Configuration") Set Fields = objConfig.Fields With Fields .Item(cdoSendUsingMethod) = cdoSendUsingPort .Item(cdoSMTPServer) = "mail.xxx.com" '你的发送邮件所在的邮件smtp地址 .Item(cdoSMTPServerPort) = 25 .Item(cdoSMTPConnectionTimeout) = 10 .Item(cdoSMTPAuthenticate) = cdoBasic .Item(cdoSendUserName) = "xxx" '你的发送邮件的登录名 .Item(cdoSendPassword) = "***" '你的发送邮件的密码 .Update End With Set objMessage = Server.CreateObject("CDO.Message") Set objMessage.Configuration = objConfig With objMessage .To = "rain518.xxx@spaces.live.com" '第一步设置中得到的日志收件地址 .From = "webmaster@baifaqimei.com" '这里显示发件人是谁 .Subject = strTitle .HTMLBody = strBriefBody .Send End With Set Fields = Nothing Set objMessage = Nothing Set objConfig = Nothing if err.number=0 then SendMail="#ok" End If end function %>

[/code]
命名为sendmail.asp文件

第三步,打开blogpost.asp文件,在第一行加入
[code]

[/code]

然后再57行左后,在
[code]
postLog = lArticle.postLog

[/code]
之后加入如下代码
[code]
dim strTitle,strBriefBody,strPre,strid
strBriefBody=lArticle.logMessage
strTitle=lArticle.logTitle
strPre= "

==========
白发齐眉网自动发送
==========

"

if len(strBriefBody)>300 then
strBriefBody =left(strBriefBody,300) & "…"
Else
strBriefBody = strBriefBody
end if

strid=Clng(lArticle.getid())

strBriefBody = Replace(strBriefBody,chr(13)&chr(10),"
")
strBriefBody= strBriefBody & "

点这里浏览完整的文章"
strBriefBody=strPre & strBriefBody

if Request.Form("checkbox")= "checkbox" then
Call Send(strTitle,strBriefBody)
end if
[/code]

第四步,修改
class\cls_logAction.asp文件
在50行左后,新加一个函数
[code]

public function getid()
sqlString="Select top 1 * FROM blog_Content orDER BY log_ID DESC "
weblog.Open sqlString,Conn,1,3
getid=weblog("log_ID")
weblog.close
end function

[/code]

本代码在pjblog v2.7 build05下通过没问题,应该在2.6上也是没问题的,只是可能blogpost文件的行数有点不一样,另,因本人时间匆忙,没来得及优化,参数传递以及变量的设置可能有多余,请看官自行修改。

附上修改好的文件,如pjblog没有修改过,可以直接覆盖更新。

点击下载此文件

不能保证一定正确,请修改前务必备份!

Asp中代码与页面的分离

为了避免ASP程序和HTML代码混写造成维护困难的情况,本文介绍了一种方法,利用模板来分离程序和页面,使程序设计更加轻松。

在使用ASP制作一个站点的时候,常常会出现一个ASP文件中,程序代码和HTML代码混合的情况。这样子做有许多缺点:
1. 且不说编程时就要对页面布局进行设计和编排,造成代码混乱难懂,不规范;
2. 当需要改变页面外观时,你不仅要改变HTML部份,也需要改变ASP代码,不易维护。

那么,要如何才能避免这些麻烦呢?
答案就是使用模板文件,将ASP代码和HTML页面分开,一切问题就都解决了。使用模板有以下好处:
1. 在很短的时间内可以替换整个站点的外观;
2. 使程序员可以抽象编程,而无须接触HTML代码;
3. 可以重复利用以前的模板。

使用过PHP的程序就会知道,PHP有个模板程序(FastTemplate),现在的问题是如何在ASP中实现类似的功能。
Microsoft的ASP带有两种脚本:VBScript和JScript。它们都带有一个 "正则表达式对象" (RegExp),利用字符串对象和RegExp对象,就可以轻松的实现模板功能。沐枫以此编写了一个 "Template.JScript.INC" 文件,此文件的内容附在文章后面。有能力的读者可以根据自己的需要进行改进。

下面介绍一下使用方法。由于此文件是使用JScript编写的(当然要转成VBScript也很容易),因此,缺省脚本语言要设为JScript,即ASP程序第一行应为:<%@Language=JScript%>,然后再包含模板程序文件:

先介绍一下Template类的使用:
1. 建立Template对象:Template(Path)
参数:Path(字符串类型) HTML模板文件的存放路径。
使用new 操作符建立Template对象。

例子:
var tpl = new Template("c:\\template");

在程序中可以用tpl.TplPath来取得模板路径,也可以通过tpl.TplPath来改变模板路径。
如:
tpl.TplPath = "d:\\template";

2. 装载模板文件:Template.Load(Name, File)
参数:Name(字符串类型) 是一个模板变量名。
File(字符串类型) 模板文件名。此文件存放在HTML模板路径下。
读取文件File到模板变量Name中。

例子:
tpl.Load("Main", "TEST.HTM");

此时,模板变量Main就包含了文件TEST.HTM的内容。
你可以用tpl.Main来访问模板变量"Main"。

例子:
<%=tpl.Main%>
将显示刚才读进来的TEST.HTM文件内容。

3. 模板分拆:Template.Split(Name)
参数:Name(字符串类型) 是一个模板变量名。
将Name中的子模板分解。

例子:
先假设上例中的TEST.HTM内容为:
——————-
这是主模板。接下来是:SUB子模板,还有
THIRD模板。

——————-
那么:
tpl.Split("Main");
执行以后,就会生成新的模板变量"SUB",和"THIRD",它们的内容就是之间语句。
而且"Main"模板变量的内容也会发生改变:

tpl.Main 的内容为:"这是主模板。接下来是{SUB}"
tpl.SUB 的内容为:"SUB子模板,还有{THIRD}"
tpl.THIRD 的内容为:"THIRD模板。"

TPLDEF 和 TPLEND 定义的语句块充许多重嵌套。

4. 模板处理:Template.Parse(Name)
参数:Name(字符串类型) 是一个模板变量。
将模板中用花括号括起来的字串用同名的模板变量的内容替换。

例子:续上例
<%=tpl.Parse("Main")%>
显示:"这是主模板。接下来是SUB子模板,还有{THIRD}"

由例子可知,Parse只替换"Main"模板中的{SUB}变量,而不能嵌套替换下去。这是为了增加程序灵活性而故意设计的。那么该怎么样完整显示"Main"模板呢?

例子:
tpl.SUB = tpl.Parse("SUB"); //先处理SUB变量,再处理Main变量。
Response.write(tpl.Parse("Main"));

5. 自定义模板变量。
自定义模板变量很简单,可以直接用赋值语句来定义和修改任何变量:

例子:
tpl.Hahaha = "这是自定义变量";
tpl.THIRD = "改变原模板中的THIRD变量";

需要注意的是,由于JScrip是区分大小写的,因此一定要注意大小写的拼写。一般来说,HTML模板中定义的模板变量都用大写。

另外,模板中使用的"TplPath","Load","Parse","Split"变量是内部使用的,不要挪做它用,否则程序将可能发生异常。

下面举个完整的例子:

第一步:先建立Html模板文件。

这里先说明HTML模板文件的组成。首先,它和普通的HTML文件几乎没有区别,只不过多了几个标记。
模板的标记有两种。让我们先看一个例子:

TEST.HTM
—————–


范例


这是一个表格范例。

10


X X的平方
{X} {XX}

以上共有{COUNT}行数据。


—————–

从上面可以看出,象{X},{XX},{COUNT}之类的记号是定义模板变量。它们将会在ASP程序中被替代。
是定义一个语句块"ROW"。在ASP程序中就可以将"ROW"块重复多次。

第二步:设计ASP程序。

TEST.ASP
——————-
<%@Language=JScript%>

<% var tpl = new Template("c:\\Inetpub\\wwwroot"); var str=""; var i; tpl.Load("Main","TEST.HTM"); tpl.Split("Main"); tpl.COUNT = 0; for(i=1;i<=tpl.MAXX;i++) //tpl.MAXX在模板中定义为10。 { tpl.X = i; tpl.XX = i*i; str+=tpl.Parse("ROW"); tpl.COUNT++; } tpl.ROW = str; tpl.MAXX =""; //清空此模板变量,以避免被显示出来。 %>
<%=tpl.Parse("Main")%>
——————-
上面的程序将显示一个1到10的平方表。

通常在使用模板的情况下,都只要在最后一行加上显示页面的语句。因此整个程序显得十分清晰。此时,只要对模板文件进行编辑,就可以改变整个页面的外观。
至于模板文件,它可以是任何文件,如HTML文件、ASP文件,甚至是程序本身!,而且在一个程序中可以装载多个模板配合使用,这样,不仅具有极大灵活性,而且模板文件与ASP程序的相关性可减到最低程度。
好好利用模板,将会使你的工作更加轻松。

附:Template 源程序
————————————

<% /*********************************************************/ /* Template Class */ /* Author: */ /* Date: 6-09 */ /*********************************************************/ //Template Method Define function Template_Parse(name) { if(this[name]==null) return ""; var reg = new RegExp("{(\\w*)}","ig"); var str = new String(this[name]); var arr = str.match(reg); var i; if(arr != null) for(i=0;i((.|\\n)*)","i");
while(this[name].search(Template_Exp)!=-1)
{
arr = this[name].match(Template_Exp);

this[arr[1} = arr[2];
this[name] = this[name].replace(Template_Exp,"{"+arr[1]+"}");
this.Split(arr[1]);
}
}

function Template_Load(name,filename)
{
var fso = new ActiveXObject("Scripting.FileSystemObject");
var file = fso.BuildPath(this.TplPath, filename);
if(fso.FileExists(file))
{
var f = fso.OpenTextFile(file, 1);
this[name] = f.ReadAll();
}
}

//Template Constructor

function Template(path)
{
//Property
this.TplPath = path;

//Method
this.Parse = Template_Parse;
this.Split = Template_Split;
this.Load = Template_Load;
}
%>