Vsdocman是一个优秀的.NET源代码注释编写工具,方便的以GUI的方式设计.NET源代码的注释。

我们知道.NET源代码的注释是Xml格式的注释,在生成程序集时,只需用选中生成Xml注释,Visual Studio根据源代码生成Xml注释文件。把程序集和相应的Xml文件拷贝到其它电脑中,在Visual Studio中编辑引用类型时,Visual Studio智能提示会提取Xml注释中的内容以方便编程开发。

.NET Xml注释的强大功能不在此多讲,我们来看一下Vsdocman提供了哪些功能令我很满意:

1 在源代码中增加,编辑和生成注释。

2 借助于所见即所得的注释编辑器(WYSIWYG comment editor)帮助编写注释。

3 很容易的直接在源代码中插入表格,列表,图片,联接,类图数据项。

4 生成专业的文档,支持多种格式和多个国家语言输出。输出格式有HTML, CHM, Docx, MS Help Viewer (help for VS 2010 and higher), Help2 (help for VS 2002-2008), RTF, XML。

5 与VS帮助系统直接集成。

6 支持命令行方式调用。

生成的输出文件格式丰富和支持命令行调用令我很满意,只需要写一个Post Build事件命令行调用即可生成文档。

安装好程序之后,Visual Studio的工具栏会多一个小按钮,源代码编辑器会增加以下三个菜单项。

Add Xml Comment 增加注释

Comment Editor 编辑注释

Add Description Attribute 增加描述,点击此菜单之后会给当前方法增加特性。比如:

[System.ComponentModel.Description("编译代码")]

举一个简单的例子,感受一下所见即所得的注释编辑器。

这样可以省略不看MSDN中关于Xml介绍的知识,以图形化方式直观简单的编写注释。

下面来看一下我是如何破解这个软件的。Vsdocman编译之后的代码经过混淆,可以用.NET Reflector反编译,查看关于对话框,可以看到有关试用的代码片段:

   1:   private void About_Load(object sender, EventArgs e)
   2:          {
   3:              try
   4:              {
   5:                  try
   6:                  {
   7:     this.Label10.Text = "Version " + Assembly.GetExecutingAssembly().GetName().Version.ToString();
   8:                  }
   9:                  catch (Exception exception1)
  10:                  {
  11:                      ProjectData.SetProjectError(exception1);
  12:                      ProjectData.ClearProjectError();
  13:                  }
  14:                  if (!Class138.smethod_0())
  15:                  {
  16:                      this.Label10.Text = this.Label10.Text + " trial";
  17:                  }
  18:                  this.Label12.Visible = false;
  19:                  this.Panel1.Visible = false;
  20:                  this.Label13.Visible = false;
  21:                  this.PanelTrial.Visible = false;
  22:                  if (!Class138.smethod_0())
  23:                  {
  24:                      this.Label13.Text = "THIS IS EVALUATION VERSION WITH 14 DAYS TRIAL PERIOD";
  25:                      this.Label13.Visible = true;
  26:                      this.Label14.Text = "You have been using VSdocman for ";
  27:                      if (Class140.smethod_5() > 1)
  28:                      {
  29:                          this.Label14.Text = this.Label14.Text + Conversions.ToString(Class140.smethod_5()) + " days.";
  30:                      }
  31:                      else
  32:                      {
  33:                          this.Label14.Text = this.Label14.Text + Conversions.ToString(Class140.smethod_5()) + " day.";
  34:                      }
  35:                      this.PanelTrial.Visible = true;
  36:                  }

第16行代码后加面了一个试用的字样,表明14行的方法返回false之后,会进入16号增加试用版字样,我们只需要将Class138.smethod_0这个方法的调用返回值改成true即可。

再来看一下Class138.smethod_0方法的源代码:

   1:   internal static bool smethod_0()
   2:          {
   3:              bool flag;
   4:              try
   5:              {
   6:                  flag = false;
   7:                  smethod_7();
   8:                  if (((string_0.Length != 0) & (class139_0.String_0.Length != 0)) && (class139_0.Int32_0 >= smethod_3()))
   9:                  {
  10:                      flag = smethod_5(string_0, class139_0.String_0);
  11:                  }
  12:              }
  13:              catch (Exception exception1)
  14:              {
  15:                  ProjectData.SetProjectError(exception1);
  16:                  ProjectData.ClearProjectError();
  17:              }
  18:              return flag;
  19:          }

以试用版的角度来看这段代码,第10行的代码应该是返回false。这时破解的思路也就产生了,修改

smethod_5方法的返回值,让它总是返回true,或者修改8行的逻辑,让条件总是false不能进入运行第10行代码,再将第6行的代码的默认值改成true,即可完成破解。我选择了后者。

安装Reflexil.Reflector.AIO插件,打开IL代码编辑窗口,直接修改IL代码,然后另存为即可。

如图中所示,第0行的默认值已经改成true,上图中第8行的判断条件,随意改成小于或是等于让它返回false即可,修改之后,再用.NET Reflector加载程序集,源代码反编译如下:

internal static bool smethod_0()
{
bool flag;
try
{
flag = true;
smethod_7();
if (!((string_0.Length != 0) & (class139_0.String_0.Length != 0)) && (class139_0.Int32_0 >= smethod_3()))
{
flag = smethod_5(string_0, class139_0.String_0);
}
}
catch (Exception exception1)
{
ProjectData.SetProjectError(exception1);
ProjectData.ClearProjectError();
}
return flag;
}

破解完毕。

Vsdocman的源代码保护方式是采用Xml签名技术,部分片段代码参考如下:

 internal static bool smethod_1(string string_2, string string_3)
{
string_2 = string_2.Trim();
string_2 = string_2.ToUpper();
string_2 = string_2.PadRight(100, '.');
string_2 = smethod_3(string_2);
byte[] bytes = new UnicodeEncoding().GetBytes(string_2);
string_3 = string_3.Replace("\r\n", string.Empty);
string_3 = string_3.Substring(0, string_3.Length - 0x10);
byte[] buffer2 = smethod_6(string_3);
RSACryptoServiceProvider provider = new RSACryptoServiceProvider();
provider.FromXmlString("<RSAKeyValue><Modulus>q/Y9KSdZYHGjjHTLtl5ZzHoaLfyBqGpTISoA98KymLZCoWiudsalpz0zORTYr7LdwHSQiDhMynAxHB2+HR2Tw1c0awwa95VcUUyFIAhTiRoDC8MNHo8R9xxiWIWp0Z1VGKqngtC9RCjdmVethIcSUc167Jw9nNLPAXC0vrmGRs0=</Modulus><Exponent>AQAB</Exponent></RSAKeyValue>");
RSAParameters parameters = provider.ExportParameters(false);
provider.FromXmlString("<RSAKeyValue><Modulus>q/Y9KSdZYHGjjHTLtl5ZzHoaLfyBqGpTISoA98KymLZCoWiudsalpz0zORTYr7LdwHSQiDhMynAxHB2+HR2Tw1c0awwa95VcUUyFIAhTiRoDC8MNHo8R9xxiWIWp0Z1VGKqngtC9RCjdmVethIcSUc167Jw9nNLPAXC0vrmGRs0=</Modulus><Exponent>AQAB</Exponent></RSAKeyValue>");
parameters = provider.ExportParameters(false);
return smethod_2(bytes, buffer2, parameters);
}

这与我的文章《大型.NET商业软件保护技术》中介绍的第3条技术相同。

完整的安装程序和破解文件下载:vsdocman_7_1_setup

安装完成之后,直接将VSdocman2.dll覆盖到安装目录中即可。

程序仅仅限于交流和学习,切勿用于商业用途。

分析优秀的.NET 文档设计工具Vsdocman 7.1 软件保护技术的更多相关文章

  1. api文档设计工具:RAML、Swagger

    api文档设计工具是用来描述和辅助API开发的. 一.RAML https://raml.org/ https://wenku.baidu.com/view/9523238d5ef7ba0d4b733 ...

  2. Api接口文档管理工具,你知道哪些呢?

    上周看到有人在我的Github开源项目中提了个issue,说是否考虑接入swagger.那今天我就用swagger与其他接口文档工具做对比,同时说说Api接口文档工具的那点事.如今,在前后端分离开发的 ...

  3. 【转载】Java Restful API 文档生成工具 smart-doc

    谁说生成api文档就必须要定义注解? 谁说生成接口请求和返回示例必须要在线? 用代码去探路,不断尝试更多文档交付的可能性. 如果代码有生命,为什么不换种方式和它对话! 一.背景 没有背景.就自己做自己 ...

  4. API文档管理工具-数据库表结构思考.

    API文档管理工具-数据库表结构思考. PS: 管理工具只是为了方便自己记录API的一些基本信息,方便不同的开发人员 (App Developer, Restful API Developer)之间的 ...

  5. 【C#附源码】数据库文档生成工具支持(Excel+Htm)

    数据库文档生成工具是用C#开发的基于NPOI组件的小工具.软件源码大小不到10MB.支持生成Excel 和Html 两种文档形式.了解更多,请访问:http://www.oschina.net/cod ...

  6. Java 的 Api 文档生成工具 JApiDocs 程序文档工具

    JApiDocs 详细介绍 简介 JApiDocs 是一个符合 Java 编程习惯的 Api 文档生成工具.最大程度地利用 Java 的语法特性,你只管用心设计好接口,添加必要的注释,JApiDocs ...

  7. 工具:使用过的 API 文档生成工具

    背景 2012 年之前几乎没有为代码增加注释,当然,代码的命名也不见得合理(好的代码胜过面面俱到的注释),后来接触过一些开源框架,优秀的框架都有一个特点:文档和示例非常多,在后来的日子里,几乎会强制自 ...

  8. 基于Mybatis的Mysql数据库文档生成工具,支持生成docx(原创)

    今天不写android--也写写数据库相关的东西 -------------------- 今日老夫闲来无事,设计了一款数据库文档生成工具 眼下仅仅支持mysql 主要是生成docx的 下载链接:下载 ...

  9. API文档管理工具

    系统庞大之后,前后端分离开发,前端调用后端提供的接口,请求协议一般是 HTTP,数据格式一般是 JSON.后台只负责数据的提供和计算,而完全不处理展现逻辑和样式:前端则负责拿到数据,组织数据并展现的工 ...

随机推荐

  1. IB交换机配置命令总结

    串口通过远程CRT登录,波特率9600用户名和密码都是adminDo you want to use the wizard for initial configuration?选择no打开ip rou ...

  2. Fix git 提交代码错误

    今天用git clone下代码,修改,push提交,发现以下错误 [root@localhost gocache]# git push origin master error: The request ...

  3. .NET 4.5+项目迁移.NET Core的问题记录

    .NET 4.5+项目迁移.NET Core的问题记录 这几天试着把目前的开发框架迁移到新的.net core平台,中间遇到的问题在这里简单记录一下. 迁移过程遇到的最大的问题IOC容器.我目前使用的 ...

  4. viojs1908无线网路发射器选址

      描述 随着智能手机的日益普及,人们对无线网的需求日益增大.某城市决定对城市内的公共场所覆盖无线网. 假设该城市的布局为由严格平行的 129 条东西向街道和 129 条南北向街道所形成的网格状,并且 ...

  5. BNUOJ 51279[组队活动 Large](cdq分治+FFT)

    传送门 大意:ACM校队一共有n名队员,从1到n标号,现在n名队员要组成若干支队伍,每支队伍至多有m名队员,求一共有多少种不同的组队方案.两个组队方案被视为不同的,当且仅当存在至少一名队员在两种方案中 ...

  6. Linux 常用工具小结:(5) lftp工具使用

    Linux 常用工具小结:(1) lftp工具使用. 这里会按照一些比较常用的功能列出,并举一个具体的例子逐一解释功能. 通常使用ftp过程是登陆ftp,浏览ftp内容,下载ftp文件,或者上传ftp ...

  7. ios 随记录

    1. 设置全局的就不写了.当单个VC需要的时候.一般是这样子. /* 设置StatusBar的样式,UIStatusBarStyleDefault与UIStatusBarStyleLightConte ...

  8. 欢迎访问我的最新个人技术博客http://zhangxuefei.top

    博客园已停止更新,欢迎访问我的最新个人技术博客http://zhangxuefei.top

  9. Java设计模式2:简单工厂模式

    简单工厂模式 简单工厂模式是类的创建模式,又叫做静态工厂方法模式.简单工厂模式由一个工厂对象决定生产出哪一种产品类的实例. 为什么要使用简单工厂模式 原因很简单:解耦. A对象如果要调用B对象,最简单 ...

  10. [.net 面向对象程序设计进阶] (2) 正则表达式 (一) 快速入门

    [.net 面向对象程序设计进阶] (2) 正则表达式 (一) 快速入门 1. 什么是正则表达式? 1.1 正则表达式概念 正则表达式,又称正则表示法,英文名:Regular Expression(简 ...