以文本方式查看主题

-  Foxtable(狐表)  (http://www.foxtable.com/bbs/index.asp)
--  专家坐堂  (http://www.foxtable.com/bbs/list.asp?boardid=2)
----  求专家解答  (http://www.foxtable.com/bbs/dispbbs.asp?boardid=2&id=176435)

--  作者:denghui69986
--  发布时间:2022/4/13 10:21:00
--  求专家解答
图片点击可在新窗口打开查看图片点击可在新窗口打开查看3、授权按钮的代码设置为:

Dim kh As String = e.Form.Controls("TextBox1").Text
Dim
 rq As String =  Format(e.Form.Controls("DateTimePicker1").Value,"yyyy-MM-dd")
Dim
 cs As String = e.Form.Controls("NumericComboBox1").Value
Dim
 qd As String = "     " \'5个半角空格,用于初始化保存实际启动次数的存储器空间.
Dim
 pw1 As String = "46DFA0D7"
Dim
 pw2 As String = "C292C1DB"
kh
 = kh.PadRight(50," ").SubString(0,50\'客户名称最多50个字符,不够50用空格补
cs
 = cs.PadRight(5," ").Substring(0,5\'启动次数最多允许5位数,不够的用空格补
If
 UKey.Start() Then
    If UKey.WriteStr(0,kh,pw1,pw2) AndAlso UKey.WriteStr(50,rq,pw1,pw2) AndAlso UKey.WriteStr(60,cs,pw1,pw2) AndAlso UKey.WriteStr(65,qd,pw1,pw2)
        Messagebox.Show(
"
授权成功!","提示", MessageBoxButtons.OK,MessageBoxIcon.Information)
    Else
        Messagebox.Show(
"
写入授权信息失败!","提示", MessageBoxButtons.OK,MessageBoxIcon.Information)
    
End If
Else

    Messagebox.Show("请插上UKey!","提示", MessageBoxButtons.OK,MessageBoxIcon.Information)

End
 If

你也许会奇怪,为什么客户名称和次数,都要固定长度,不够的补空格?
你想一下,如果你之前已经对某个UKey进行过授权,授权客户是“北京市公安局”,现在想重新授权,将客户改为“联想电脑”,如果不采用固定长度且补空格的方式,那么重新授权后,客户名称将是"联想电脑安局"。

5、现在回到原来的项目中,将项目事件BeforeOpenProject事件代码设置为:

If UKey.Start() Then
    If 
UKey.Encrypt2("abc") <> "483DBF9FDD0574C0" Then
        
MessageBox.Show("请插上XX公司提供的UKey!","提示",MessageBoxButtons.OK,MessageBoxIcon.Information)
        
e.Cancel = True
    Else
        Dim 
khs As String = UKey.ReadStr(0,50\'从存储器读取04950个字节的内容,也就是授权客户名称
        Dim 
rqs As String = UKey.ReadStr(50,10\'从存储器读取505910个字节的内容,也就是截止日期
        Dim 
css As String = UKey.ReadStr(60,5\'从存储器读取60645个字节的内容,也就是允许启动次数
        Dim 
yqs As String = UKey.ReadStr(65,5\'从存储器读取65695个字节的内容,也就是已经启动次数
        Dim 
rq As Date
        Dim 
cs As Integer
        Dim 
qs As Integer
        
\'从存储器读取出来值的是字符,所以还需要转换一下,因为截止日期是Date型,次数是Integer型
        
Date.TryParse(rqs,rq)
        
Integer.TryParse(css,cs)
        
Integer.TryParse(yqs,qs)
        
qs = qs + 1 \'已经启动次数加1
        UKey.WriteStr(65,qs,"46DFA0D7","C292C1DB"\'将已经启动次数写入存储器
        
If qs > cs \'如果已经启动次数大于允许启动次数
            
MessageBox.Show("你的UKey已经超过允许启动次数!","提示",MessageBoxButtons.OK,MessageBoxIcon.Information)
            
e.Cancel = True
        ElseIf 
Date.Today > rq \'如果今天的日期大于截止日期
            
MessageBox.Show("你的UKey已经过期!","提示",MessageBoxButtons.OK,MessageBoxIcon.Information)
            
e.Cancel = True
        End If
        If 
e.Cancel = False Then
            
MessageBox.Show("尊敬的用户" & khs.Trim() & ",欢迎使用本软件!","提示",MessageBoxButtons.OK,MessageBoxIcon.Information)
        End If
    End If
Else
    
MessageBox.Show("启动UKey失败!","提示",MessageBoxButtons.OK,MessageBoxIcon.Information)
    
e.Cancel = True
End If

上面的代码采用用户加密函数Encrypt2判断用户已经插上你公司提供的UKey,并判断此UKey是否还在授权范围之内,所有条件符合才允许打开你的项目。

7、最后增加一个计划,执行间隔为10000毫秒,也就是10秒,计划代码为:

If UKey.Encrypt1("abc") <> "E5FC1B19625C5C4A" Then
    
MessageBox.Show("请插上XX公司提供的UKey!","提示",MessageBoxButtons.OK,MessageBoxIcon.Information)
    DataTables.Save()
    Syscmd.Project.
Exit

End
 If


我复制按照以上代码设置,求专家指导,谢谢


--  作者:有点蓝
--  发布时间:2022/4/13 10:29:00
--  
有购买官方的ukey了吗?

把ukey插上usb口,填入需要授权的用户名称,执行代码即可

--  作者:denghui69986
--  发布时间:2022/4/13 11:03:00
--  
没有买,ukey是在你们官网买码?



--  作者:有点蓝
--  发布时间:2022/4/13 11:16:00
--  
联系客服,QQ:800014337