Foxtable(狐表)用户栏目专家坐堂 → 为什么无法修改连接字符串?


  共有3869人关注过本帖树形打印复制链接

主题:为什么无法修改连接字符串?

帅哥哟,离线,有人找我吗?
sloyy
  1楼 | QQ | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2193 积分:13908 威望:0 精华:2 注册:2012/2/25 10:59:00
为什么无法修改连接字符串?  发帖心情 Post By:2020/1/22 14:19:00 [只看该作者]

我在BeforeConnectOuterDataSource事件里写了如下代码:
If e.Name = "zbxt" Then
    If Network.Ping("www.163.com",1000) = False  Then '如果网易无法接通
        e.ConnectionString = e.ConnectionString.Replace("110.20.199.135", "192.168.2.27")
    End If
End If

结果在外网运行正常,在内网无法切换到192.168.2.27

哪里出问题了?
[此贴子已经被作者于2020/1/22 14:19:26编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110648 积分:563148 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/1/22 14:33:00 [只看该作者]

参考:http://www.foxtable.com/webhelp/topics/2709.htm,如果断网,ping是会出错的,导致后面的代码不执行。如果没有断网,ping肯定是通的,也不会执行后面的代码。所以这种用法仅支持局域网没有外网连接的情况

If e.Name = "zbxt" Then
    If TryConnectHost("www.163.com")=False  Then '如果网易无法接通
        e.ConnectionString = e.ConnectionString.Replace("110.20.199.135", "192.168.2.27")
    End If
End If

 回到顶部
帅哥哟,离线,有人找我吗?
sloyy
  3楼 | QQ | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:九尾狐 帖子:2193 积分:13908 威望:0 精华:2 注册:2012/2/25 10:59:00
  发帖心情 Post By:2020/1/22 14:56:00 [只看该作者]

谢谢有点蓝大师,确实如此.
改用:TryConnectHost("www.163.com") 
问题顺利解决,内外网切换无障碍了.

 回到顶部