#include <stdio.h>
#include <stdlib.h>
#include<windows.h>

char GetSystemDisk(){
    char str[255];
    GetSystemDirectory(str, 255);
    return str[0];
}
char* merge(char *s1,char *s2,char* des){
    int length1=strlen(s1);
    int length2=strlen(s2);
    int sumLength=length1+length2;
    des=(char *)malloc(sizeof(char)*sumLength+1);
    int i=0;
    for(;i<sumLength;i++){
        if(i<=length1-1)
            des[i]=s1[i];
        else
            des[i]=s2[i-length1];
    }
    des[i]='\0';
    return des;
}
void strrpl(char* pDstOut, char* pSrcIn, const char* pSrcRpl, const char* pDstRpl)
{
char* pi = pSrcIn;
char* po = pDstOut;

int nSrcRplLen = strlen(pSrcRpl);
int nDstRplLen = strlen(pDstRpl);

char *p = NULL;
int nLen = 0;

do
{
// 找到下一个替换点
p = strstr(pi, pSrcRpl);

if(p != NULL)
{
// 拷贝上一个替换点和下一个替换点中间的字符串
nLen = p - pi;
memcpy(po, pi, nLen);

// 拷贝需要替换的字符串
memcpy(po + nLen, pDstRpl, nDstRplLen);
}
else
{
strcpy(po, pi);

// 如果没有需要拷贝的字符串,说明循环应该结束
break;
}

pi = p + nSrcRplLen;
po = po + nLen + nDstRplLen;

} while (p != NULL);
}
void contact(char str1[],char str2[])
{
 char *p1,*p2;
 int length1 = 0,length2 = 0;
 int i;
 p1 = str1;
 p2 = str2;
 while(*p1)
 {
  p1++;
  length1++;
 }
 while(*p2)
 {
  p2++;
  length2++;
 }
 for(i = 0;i < length1;i++)
  str2[length2+i] = str1[i];
 str2[length1+length2] = '\0';
}
int file_exists(char *filename)
{
    return (access(filename, 0) == 0);
}
int main()
{
    char c=GetSystemDisk();
    char order[255]="C:\\WINDOWS\\Microsoft.NET\\Framework\\v2.0.50727\\regasm.exe /codebase /tlb";
    char path[255]="C:\\WINDOWS\\Microsoft.NET\\Framework\\v2.0.50727\\regasm.exe";
    order[0]=c;
    int existFile=file_exists(path);
    char result[400];
    char szFull[400];
    GetModuleFileName(NULL,szFull,400);
    if(existFile!=1){
        printf("安装.NET运行时,请等待....\n");
        char result2[400];
        strrpl(result2,szFull,"patentstart.exe","2.0.exe");
        system(result2);
    }
    //启动路径

strrpl(result,szFull,"patentstart.exe","PatentActiveX.dll");
    printf("%s\n",result);
    int resultLength=strlen(result);
    //
    char dllPath[500];
    dllPath[0]='"';
    int j=1;
    for(;j<=resultLength;j++){
        dllPath[j]=result[j-1];
    }
    dllPath[j]='"';
    dllPath[j+1]='\0';
    printf("%s\n",dllPath);
    //

char fullOrder[900];
    int orderLength=strlen(order);
    int dllPathLength=strlen(dllPath);
    int i=0;
    for(;i<orderLength;i++){
        fullOrder[i]=order[i];
    }
    fullOrder[orderLength]=' ';
    for(i=orderLength+1;i<=orderLength+dllPathLength+1;i++){
        fullOrder[i]=dllPath[i-orderLength-1];
    }
    printf("%s\n",fullOrder);
    system(fullOrder);
    //system("cls");
    printf("注册成功,刷新IE页面有效\n");
    MessageBox(NULL,"注册成功,刷新IE页面有效","提示",MB_OK);
    return 0;
}

.NET 2.0 检测的更多相关文章

  1. 解决:Android 8.0检测不到当前的activity

    前两天从Android 7.0升级到Android 8.0,今天在用 adb shell dumpsys activity | findstr "mFocusedActivity" ...

  2. HTTP 错误 500.23 - Internal Server Error 检测到在集成的托管管道模式下不适用的 ASP.NET 设置。

    检测到在集成的托管管道模式下不适用的ASP.NET设置的解决方法(非简单设置为[经典]模式). - CatcherX 2014-03-11 11:03 27628人阅读 评论(2) 收藏 举报  分类 ...

  3. 检测访问网页的浏览器呈现引擎、平台、Windows操作系统、移动设备和游戏系统

    /** * Author: laixiangran. * Created by laixiangran on 2015/12/02. * 检测访问网页的浏览器呈现引擎.平台.Windows操作系统.移 ...

  4. PBOC2.0与PBOC3.0的区别

    2013年2月,中国人民银行发布了<中国金融集成电路(IC)卡规范(V3.0)>(以下简称PBOC3.0),PBOC3.0是在中国人民银行2005年颁布的<中国金融集成电路(IC)卡 ...

  5. javascript关于检测浏览器和操作系统的问题

    1.方法学: 最好是检测浏览器的最小版本,这样才不会当版本升级之后不断添加新的内容进去. 理想的方式: if(isMinIE5){ //code } 直接检查准确的版本的缺点: if(isMinIE5 ...

  6. YUI的UA检测

    YUI.UA是针对javascript的宿主环境检测的一个检测对象,返回的是一系统关于当前宿主的信息 1.对象相关信息列表及userAgent 检测对象o = { ie: 0, //ie Mozill ...

  7. 基于Xcode8插件开发~一键检测处理头文件引用

    Xcode8开放了新的一个Extension:Xcode Source Editor Extension,目的是让开发者可以正规的自主为IDE编写插件,虽然说系统现提供的功能还比较拮据,但是不妨碍我们 ...

  8. 用户代理字符串(navigator.userAgent)检测方法

    最近在看<JavaScript 高级程序设计(第三版)>,发现其中关于用户代理字符串检测技术的一些方法,觉得讲的很详细.用户代理字符串(navigator.userAgent)中包含了大量 ...

  9. vue-cli3.0使用及配置

    1.先全局安装vue-cli3.0 检测安装: vue -V 2.创建项目(这个就跟react创建脚手架项目比较像了)   这里如果你是第一次用3.0版本的话,是没有前两个的,而只有最后两个,这里是 ...

随机推荐

  1. 跨平台开源通讯组件elastic communication

    elastic communication是基于c#开发支持.net和mono的通讯组件(简称EC),EC的主要目的简化mono和.net下的通讯开发难度,通过EC可以非常快速地开发基于mono和.n ...

  2. Snmp协议应用-扫描局域网内打印机

    .h2cls { background: #6fa833 none repeat scroll 0 0 !important; color: #fff; font-family: "微软雅黑 ...

  3. [后端人员耍前端系列]KnockoutJs篇:快速掌握KnockoutJs

    一.引言 之前这个系列文章已经介绍Bootstrap.由于最近项目中,前端是Asp.net MVC + KnockoutJs + Bootstrap来做的.所以我又重新开始写这个系列.今天就让我们来看 ...

  4. RCP: JDT 根据org.eclipse.jdt.core.IJavaElement对象获取org.eclipse.jdt.core.dom.ASTNode对象

    JDT中有两套Java文件模型映射. 其核心类\接口分别为: org.eclipse.jdt.core.IJavaElement和org.eclipse.jdt.core.dom.ASTNode IJ ...

  5. guava之Joiner 和 Splitter

    最近在给客户准备一个Guava的分享,所以会陆续的更新关于Guava更多的细节分享.本文将记录Guava中得字符串处理Joiner(连接)和Splitter(分割)处理. Joiner 首先我们来看看 ...

  6. 在.net中使用aquiles访问Cassandra(四)

    数据的持久化我们都已经完成了,和所有应有程序一样,最重要的是要向用户展示数据.下面我们就推出这部分代码,读取任意行任何列: public IList<TRowResult> Execute ...

  7. [每日电路图] 1、基于AT89C52单片机最小系统接口电路【转】

              come from:http://www.21ic.com/dianlu/basis/interface/2015-04-21/621607.htm AT89C52是美国Atmel ...

  8. Senparc.Weixin.MP SDK 微信公众平台开发教程(十六):AccessToken自动管理机制

    在<Senparc.Weixin.MP SDK 微信公众平台开发教程(八):通用接口说明>中,我介绍了获取AccessToken(通用接口)的方法. 在实际的开发过程中,所有的高级接口都需 ...

  9. Atitit 常见的树形结构 红黑树  二叉树   B树 B+树  Trie树 attilax理解与总结

    Atitit 常见的树形结构 红黑树  二叉树   B树 B+树  Trie树 attilax理解与总结 1.1. 树形结构-- 一对多的关系1 1.2. 树的相关术语: 1 1.3. 常见的树形结构 ...

  10. 3 分钟轻松搭建 Ruby 项目自动化持续集成

    任何事情超过 90 秒就应该自动化,这是程序员的终极打开方式.Automating shapes smarter future. 这是一篇关于 Ruby 项目持续集成的快速指导教程,教大家如何使用 f ...