番外篇 之 JS调用
| C#Winform调用JS
执行JS(Javascript)方法
课前知识储备:
1,JS代码放置的位置。
方法一: 使用微软官方组件Interop.MSScriptControl
ScriptControlClass sc = new ScriptControlClass();//申明变量
sc.UseSafeSubset = true; //允许执行不安全的代码
sc.Language = "JScript"; //VBScript
sc.AddCode(Properties.Resources.GetTimes);// Properties.Resources 资源文件
要执行的方法名,执行的参数/如果无参那么就写方法名
string str = sc.Run("time", newobject[] { "time()"}).ToString();
//特别注意
当JS方法中无参数时,这时传递的为该方法名称.
弊端:
必须携带DLL.
不支持x64 .
区别: 方法一需要DLL,方法二反射的方法是不需要DLL的.
方法一不支持X64,方法二支持.
方法二在需要参数是字符串时,必须要使用 ”’”引号包起来.方法一则不用
方法二: 利用反射获取组件
/// <summary>
/// 获取JS时间戳 13位 /// </summary> /// <returns></returns> public string GetTimeByJs(string name) { Type obj = Type.GetTypeFromProgID("ScriptControl"); //从标识符中得到当前的type对象 if (obj == null) { return null; } object ScriptControl = Activator.CreateInstance(obj);//将得到的Type创建实例. obj.InvokeMember("Language", BindingFlags.SetProperty, null, ScriptControl, new object[] { "JScript" }); string js = "function time(name){return '你好' + name}"; obj.InvokeMember("AddCode", BindingFlags.InvokeMethod, null, ScriptControl, new object[] { js }); return obj.InvokeMember("Eval", BindingFlags.InvokeMethod, null, ScriptControl, new object[] { "time('" + name + "')" }).ToString(); } 不得不说的方法:
在环境变量里面-系统变量-path-点编辑,在末尾添加";.netframework(注意编译版本)绝对路径"注意前面还有个分号,系统变量中不能有中文,空格..O了.直接cmd jec 调用编译就可以了. 例如:"jsc /t:library xxx.js"
|
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using MSScriptControl;
using System.Reflection; namespace JsDemo
{
public partial class Form1 : Form
{ public Form1()
{
InitializeComponent();
}
/// <summary>
/// 密码加密
/// </summary>
/// <param name="pass"></param>
/// <returns></returns>
public string EncodePass(string pass)
{
ScriptControlClass sc = new ScriptControlClass();
sc.UseSafeSubset = true;
sc.Language = "JScript";
sc.AddCode(Properties.Resources.GetTimes);
//string str = sc.Run("b64_sha1", new object[] { pass }).ToString();
string str = sc.Run("time", new object[] { "君临" }).ToString();
return str;
}
private void btnEncrypt_Click(object sender, EventArgs e)
{
string Enstr = txtEnStr.Text;
txtDeStr.Text=EncodePass(Enstr);
//txtDeStr.Text = GetTimeByJs(Enstr);
} private void Form1_Load(object sender, EventArgs e)
{ } /// <summary>
/// 获取JS时间戳 13位
/// </summary>
/// <returns></returns>
public string GetTimeByJs(string name)
{
Type obj = Type.GetTypeFromProgID("ScriptControl"); //从标识符中得到当前的type对象
if (obj == null)
{
return null;
}
object ScriptControl = Activator.CreateInstance(obj);//将得到的Type创建实例.
obj.InvokeMember("Language", BindingFlags.SetProperty, null, ScriptControl, new object[] { "JScript" });
string js = "function time(name){return '你好' + name}";
obj.InvokeMember("AddCode", BindingFlags.InvokeMethod, null, ScriptControl, new object[] { js });
return obj.InvokeMember("Eval", BindingFlags.InvokeMethod, null, ScriptControl, new object[] { "time('" + name + "')" }).ToString();
}
}
}
视频教程出自:http://www.xuanjics.com/thread-86-1-1.html
玄机论坛的地址:www.xuanjics.com 原创作者:君临
番外篇 之 JS调用的更多相关文章
- #3使用html+css+js制作网页 番外篇 使用python flask 框架 (II)
#3使用html+css+js制作网页 番外篇 使用python flask 框架 II第二部 0. 本系列教程 1. 登录功能准备 a.python中操控mysql b. 安装数据库 c.安装mys ...
- #3使用html+css+js制作网页 番外篇 使用python flask 框架 (I)
#3使用html+css+js制作网页 番外篇 使用python flask 框架(I 第一部) 0. 本系列教程 1. 准备 a.python b. flask c. flask 环境安装 d. f ...
- #3使用html+css+js制作网页 番外篇 制作接收php
使用html+css+js制作网页 番外篇 制作接收php 本系列链接 基础 php语法 例子 本系列链接 #1使用html+css+js制作网站教程 准备 #2使用html+css+js制作网站教程 ...
- 【番外篇】ASP.NET MVC快速入门之免费jQuery控件库(MVC5+EF6)
目录 [第一篇]ASP.NET MVC快速入门之数据库操作(MVC5+EF6) [第二篇]ASP.NET MVC快速入门之数据注解(MVC5+EF6) [第三篇]ASP.NET MVC快速入门之安全策 ...
- 渗透测试思路 - CTF(番外篇)
渗透测试思路 Another:影子 (主要记录一下平时渗透的一些小流程和一些小经验) CTF(番外篇) 笔者是一个WEB狗,更多的是做一些WEB类型题目,只能怪笔者太菜,哭~~ 前言 本篇 ...
- 《手把手教你》系列技巧篇(三十一)-java+ selenium自动化测试- Actions的相关操作-番外篇(详解教程)
1.简介 上一篇中,宏哥说的宏哥在最后提到网站的反爬虫机制,那么宏哥在自己本地做一个网页,没有那个反爬虫的机制,谷歌浏览器是不是就可以验证成功了,宏哥就想验证一下自己想法,于是写了这一篇文章,另外也是 ...
- x64 番外篇——保护模式相关
写在前面 此系列是本人一个字一个字码出来的,包括示例和实验截图.由于系统内核的复杂性,故可能有错误或者不全面的地方,如有错误,欢迎批评指正,本教程将会长期更新. 如有好的建议,欢迎反馈.码字不易, ...
- iOS冰与火之歌(番外篇) - 基于PEGASUS(Trident三叉戟)的OS X 10.11.6本地提权
iOS冰与火之歌(番外篇) 基于PEGASUS(Trident三叉戟)的OS X 10.11.6本地提权 蒸米@阿里移动安全 0x00 序 这段时间最火的漏洞当属阿联酋的人权活动人士被apt攻击所使用 ...
- 给深度学习入门者的Python快速教程 - 番外篇之Python-OpenCV
这次博客园的排版彻底残了..高清版请移步: https://zhuanlan.zhihu.com/p/24425116 本篇是前面两篇教程: 给深度学习入门者的Python快速教程 - 基础篇 给深度 ...
随机推荐
- 我所理解的网络游戏<一>:网游的顶层设计
网游的基本结构 各大模块的基本功能如下 · 服务器端 登陆服:处理新建玩家.登陆逻辑. 场景服:处理场景服中的逻辑. 中心服:处理跨服的逻辑,实现不同场景服进程的数据调度,以及向数据库查询数据. 数据 ...
- 虚幻4随笔6 Object和序列化
诚如之前所说,虚幻4主要的一些特性都是由UObject穿针引线在一起的,想把虚幻玩到比较深的程度,UObject是迟早要面对.回避不得的问题,所以,准备在其它主题之前,先把UObject好好弄一下.U ...
- 如何做好iOS应用安全?这有一把行之有效的“三板斧”
本文由 网易云发布. iOS应用面临很多破解问题,常见的有IAP内购破解.山寨版本.破解版本等:大众应用上,微信抢红包.微信多开等:而在iOS游戏上,越来越泛滥的外挂问题也不断困扰着游戏厂商. 网易 ...
- Day5 作业(完成)
1,有如下变量(tu是个元祖),请实现要求的功能# tu = ("alex", [11, 22, {"k1": 'v1', "k2": [& ...
- python打造渗透工具集
python是门简单易学的语言,强大的第三方库让我们在编程中事半功倍,今天我们就来谈谈python在渗透测试中的应用,让我们自己动手打造自己的渗透工具集. 难易程度:★★★阅读点:python;web ...
- javascript——后台传值map类型转换成json对象
前端需要对后端传过来的值进行解析之后再展示,而后端传过来的值可能是各种类型的,一般情况下要么和后端沟通下让他直接传给我们需要的类型,这个,我一般直接自己转,这次后端传回来一个map类型的对象,我转来转 ...
- Concurrent包工具类使用
一.读写锁 传统的同步锁就是独占式锁,当线程使用资源时候保持独占,无论读写.当人们发现请求队列(假设)中相邻请求为读-读的时候,阻塞是一种浪费资源的操作.比如公告板,所有路过的人(请求)都是读操作,并 ...
- OC 中的属性
自动合成 (autosynthesis) @property 语法,会做下面两件事情 自动生成存取方法 由编译器生成,编辑器里不会看到这些方法. 向类中添加适当类型的实例变量 在属性前加下划线,作为实 ...
- struts2中s:select标签的使用
1.第一个例子: <s:select list="{'aa','bb','cc'}" theme="simple" headerKey="00& ...
- WebDriver高级应用实例(1)
1.1使用JavaScriptExecutor单击元素 被测网页的网址: http://www.baidu.com Java语言版本的API实例代码 import org.testng.annotat ...