Flex通过JS获取客户端IP和计算机名的实例代码


Posted in Javascript onNovember 21, 2013

首先说明一下,用JS方式获取不是调用webservices和httpservices。

    在我们每一个FLex web工程中,都有那么一个文件夹bin-debug,里面有个index.html文件,我的个人理解是这样的,首先网页运行的时候,mxml的文件会被编译为swf,那么swf如何在浏览器中展现,就是通过这个html文件,相当于在html文件中嵌入了一个swf的object组件。 3water.com

    所以,在这个html中写入js的代码,来获取ip地址我个人觉得是可行的。因此出现以下代码。

在index.html中增加script标签,实际代码如下:

<script type="text/javascript">
function getClientPcName()
{ 
    //alert("请将您浏览器Internet选项中的“对没有标记为安全的ActiveX控件进行初始化和脚本运行”设置为“启用”!/n/n然后刷新本页登陆!");
    ///window.onerror = killErrors; +"/"+WshShell.UserName;
  var WshShellPcName = new ActiveXObject("WScript.Network");
  var ComputerName = WshShellPcName.ComputerName ;
  //添加信任站点(http://192.168.1.5)
  //alert(ComputerName); 
    return ComputerName;
  }
  function getClientIp()
  {
  var WshShellIp = new ActiveXObject("rcbdyctl.Setting");
       var ip = WshShellIp.GetIPAddress;
       return ip;
}
</script>

这样获取ip和pcname的相当于后台的代码就写好了。

如何在flex中调用呢,那就用到了Flex的这个类:flash.external.ExternalInterface。

对于ExternalInterface类,adobe是这样解释的:

ExternalInterface 类是外部 API,这是一个在 ActionScript 和 Flash Player 容器之间实现直接通信的应用程序编程接口,例如,包含 JavaScript 的 HTML 页。Adobe 建议使用 ExternalInterface 实现 JavaScript 与 ActionScript 之间的所有通信。

在 Flash Player 中,可以使用 HTML 页中的 JavaScript 来调用 ActionScript 函数。ActionScript 函数可以返回一个值,JavaScript 会立即接收它作为该调用的返回值。

此功能替代 fscommand() 方法。

在以下浏览器和操作系统的组合中可以使用 ExternalInterface 类:

浏览器 操作系统 操作系统
Internet Explorer 5.0 及更高版本 Windows
Netscape 8.0 及更高版本 Windows  MacOS
Mozilla 1.7.5 及更高版本 Windows  MacOS
Firefox 1.0 及更高版本 Windows  MacOS
Safari 1.3 及更高版本    MacOS
适用于 Linux 的 Flash Player 9.0.31.0 及更高版本在以下浏览器中支持 ExternalInterface 类:

浏览器
Mozilla 1.7.x 及更高版本
Firefox 1.5.0.7 及更高版本
SeaMonkey 1.0.5 及更高版本
ExternalInterface 类要求用户的 Web 浏览器支持 ActiveX® 或由某些浏览器公开的 NPRuntime API 以实现插件脚本处理。即使上面未列出浏览器和操作系统组合,如果它们支持 NPRuntime API,则它们也应该支持 ExternalInterface 类。
注意:在将 SWF 文件嵌入到 HTML 页中时,请确保设置 id 属性,并且 object 和 embed 标签的 id 和 name 属性不包含以下字符:

 . - + * / /

注意:Flash Player 9.0.115.0 版和更高版本允许在 id 和 name 属性中使用 .(句点)字符。

在浏览器中运行的 Flash Player 10 和更高版本中,以编程方式使用此类打开弹出窗口可能不会成功。不同的浏览器(和浏览器配置)可能会随时阻止弹出窗口;不能保证可以显示任何弹出窗口。不过,为了尽可能成功,请仅在作为用户操作的直接结果执行的代码中使用此类打开弹出窗口(例如,在鼠标单击或按键事件的事件处理函数中)。

利用 ActionScript,可以在 HTML 页上执行以下操作:

调用任何 JavaScript 函数。
传递任意数量、具有任意名称的参数。
传递各种数据类型(Boolean、Number、String 等等)。
接收来自 JavaScript 函数的返回值。
通过在 HTML 页上使用 JavaScript,可以:

调用 ActionScript 函数。
使用标准的函数调用表示法传递参数。
将值返回给 JavaScript 函数。
Flash Player 当前不支持嵌入到 HTML 表单中的 SWF 文件。

注意:在 Adobe AIR 中,ExternalInterface 类可用于在 HTMLLoader 控件中加载的 HTML 页的 JavaScript 与嵌入在该 HTML 页的 SWF 内容中的 ActionScript 之间实现通信。

在我们的mxml文件中使用这个类。进行调用js中的获取ip和pcname的函数:

pcName = ExternalInterface.call("getClientPcName");

ip =  ExternalInterface.call("getClientIp"); 

您可以尝试Alert,看一下对不对。这样还有一个问题,加入您的机器作为服务器,那么在服务器上获取到的ip会是:127.0.0.1,处理它我相信你会有办法的。

Javascript 相关文章推荐
javascript数组组合成字符串的脚本
Jan 06 Javascript
jQuery 中的 DOM 操作
Apr 26 Javascript
使用Angular.js实现简单的购物车功能
Nov 21 Javascript
Bootstrap基本组件学习笔记之进度条(15)
Dec 08 Javascript
JavaScript中offsetWidth的bug及解决方法
May 17 Javascript
Angularjs 实现动态添加控件功能
May 25 Javascript
详解angularjs 关于ui-router分层使用
Jun 12 Javascript
使用Node.js搭建静态资源服务详细教程
Aug 02 Javascript
详解webpack编译多页面vue项目的配置问题
Dec 11 Javascript
Vue使用Proxy监听所有接口状态的方法实现
Jun 07 Javascript
javascript实现简易聊天室
Jul 12 Javascript
ESLint 是如何检查 .vue 文件的
Nov 30 Vue.js
开发插件的两个方法jquery.fn.extend与jquery.extend
Nov 21 #Javascript
JS连接SQL数据库与ACCESS数据库的方法实例
Nov 21 #Javascript
js中一个函数获取另一个函数返回值问题探讨
Nov 21 #Javascript
js设置组合快捷键/tabindex功能的方法
Nov 21 #Javascript
jtable列中自定义button示例代码
Nov 21 #Javascript
动态标签 悬停效果 延迟加载示例代码
Nov 21 #Javascript
JS两种定义方式的区别、内部原理
Nov 21 #Javascript
You might like
PHP set_time_limit(0)长连接的实现分析
2010/03/02 PHP
PHP中date()日期函数有关参数整理
2011/07/19 PHP
实现PHP框架系列文章(6)mysql数据库方法
2016/03/04 PHP
PHP7.1新功能之Nullable Type用法分析
2016/09/26 PHP
Jquery实现无刷新DropDownList联动实现代码
2010/03/08 Javascript
JavaScript 模拟类机制及私有变量的方法及思路
2013/07/10 Javascript
给文字加上着重号的JS代码
2013/11/12 Javascript
完美实现bootstrap分页查询
2015/12/09 Javascript
深入php面向对象、模式与实践
2016/02/16 Javascript
jQuery的内容过滤选择器学习教程
2016/04/18 Javascript
学习AngularJs:Directive指令用法(完整版)
2016/04/26 Javascript
jquery实现瀑布流效果 jquery下拉加载新数据
2016/12/12 Javascript
老生常谈Bootstrap媒体对象
2017/07/06 Javascript
详解vue-cli本地环境API代理设置和解决跨域
2017/09/05 Javascript
JavaScript中的事件与异常捕获详析
2019/02/24 Javascript
JavaScript强制类型转换和隐式类型转换操作示例
2019/05/01 Javascript
Flutter 超实用简单菜单弹出框 PopupMenuButton功能
2019/08/06 Javascript
js实现带箭头的进度流程
2020/03/26 Javascript
JS数组Reduce方法功能与用法实例详解
2020/04/29 Javascript
javascript实现前端成语点击验证优化
2020/06/24 Javascript
Python中的文件和目录操作实现代码
2011/03/13 Python
Python中为什么要用self探讨
2015/04/14 Python
基于python yield机制的异步操作同步化编程模型
2016/03/18 Python
Python使用sorted排序的方法小结
2017/07/28 Python
教你用Python创建微信聊天机器人
2020/03/31 Python
Python数据结构之图的应用示例
2018/05/11 Python
Python使用扩展库pywin32实现批量文档打印实例
2020/04/09 Python
css3设置box-pack和box-align让div里面的元素垂直居中
2014/09/01 HTML / CSS
CSS3常用的几种颜色渐变模式总结
2016/11/18 HTML / CSS
超市实习总结自我鉴定
2013/09/19 职场文书
2014年机关植树节活动方案
2014/02/27 职场文书
心理健康日活动总结
2014/05/08 职场文书
单位考核鉴定意见
2015/06/05 职场文书
python-opencv 中值滤波{cv2.medianBlur(src, ksize)}的用法
2021/06/05 Python
sql server删除前1000行数据的方法实例
2021/08/30 SQL Server
ant design charts 获取后端接口数据展示
2022/05/25 Javascript