认识CodeSmith

article/2025/9/15 19:32:54

一:下载与激活

1.下载绿色版CodeSmith7.0

http://download.csdn.net/download/laoge/6859701

2.使用激活工具CodesmithKeyGenerator.exe激活CodeSmith7.0

(a)打开软件TemplateEditor.exe,进入CodeSmith Generator窗口,点击Register按钮;

(b)先打开激活工具CodesmithKeyGenerator.exe,进入CodeSmith KeyGenerator窗口,在Prefix里面输入:CS70P-    ,其他的保持默认,点击Generate按钮,产生serial序列号;

(c)复制serial中假的序列号到CodeSmith Generator窗口中serial number下,在CodeSmith Generator窗口填写name;

(d)点击Register按钮,点击Actiave by Entering a Code按钮,记住Machine Code中的序列号;

(e)切换到CodeSmith KeyGenerator窗口,点击Generate Activation按钮;

(f)在Prefix里面输入CS70P-  ,code里面选择时间(大于现在时间就行),手动输入Machine Code中的序列号到Machine Hash Code文本框里面,点击Generate按钮,产生真正的Activate序列号;

(g)把真正的Activate序列号复制到Activation Code文本框里面,点击Activate激活CodeSmith;

(h)运行TemplateEditor.exe,点击“Help—>About CodeSmith Generator”,如果Licensed to下显示你在(c)步输入的name,表示激活成功了。

二:CodeSmith的工作原理

①去数据库获取数据库的结构,如各个表的名称,表的字段,表间的关系等等;

②根据用户自定义好的模板文件,用数据库结构中的关键字替代模板的动态变量;

③输出并保存为我们需要的目标文件。

在CodeSmith中你可以自己定义模板来生成所有你想要的代码,也可以到CodeSmith社区http://community.codesmithtools.com/中去下载模板。

三:实例——使用CodeSmith生成分层架构的实体层

具体参照:http://www.cnblogs.com/huangcong/archive/2010/06/14/1758201.html

1.运行TemplateEditor.exe,新建CSharp Template取名为test.cst,添加代码(声明模板使用哪种语言,使CodeSmit和数据库关联起来);

<%@ CodeTemplate Language="C#" TargetLanguage="Text" Src="" Inherits="" Debug="False" CompilerVersion="v3.5" Description="Tempalte description here." %><%-- 加载访问数据库的组件SchemaExplorer,并声明其使用的命名空间 --%>
<%@ Assembly Name="SchemaExplorer"%>
<%@ Import Namespace="SchemaExplorer"%><%-- 数据库 --%>
<%@ Property Name="SourceDatabase" Type="SchemaExplorer.DatabaseSchema" DeepLoad="True" Optional="False" Category="01. GettingStarted - Required" Description="Database that the tables views, 
and storedprocedures should be based on. IMPORTANT!!! If SourceTables and SourceViews areleft blank, the Entire Database will then be generated."%>

2.新建一个文件Entity.cst,保存到test.cst所在的文件夹内,编写设计模板代码;

<%@ CodeTemplate Inherits="CodeTemplate" TargetLanguage="Text" Description="NetTiers main template."Debug="True" ResponseEncoding="UTF-8"%><%@ Assembly Name="SchemaExplorer"%>
<%@ Import Namespace="SchemaExplorer"%><%-- 要打印的表 --%>
<%@ Property Name="Table" Type="TableSchema" DeepLoad="True" Optional="False" Category="01. Getting Started - Required" Description="Database that the tables views, 
and stored procedures shouldbe based on. IMPORTANT!!! If SourceTables and SourceViews are left blank, theEntire Database will then be generated." %>using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;namespace Entity
{public partial class <%= Table.Name%>{<%foreach(ColumnSchema col in Table.Columns){ %>public <%= col.DataType %> <%=col.Name %>{ get;set; }<% } %>}
}

3.模板创建好后,要在test.cst文件中注册一下;

 
<%-- 注册实体层Entity模板 --%>
<%@ Register Name="EntityTemplate" Template=" Entity.cst"MergeProperties="Flase" ExcludeProperties=""%>
 

4.在test.cst中设置目标文件的输出目录;

<script runat="template">//解决方案输出路径
private string Directory = String.Empty;[Editor(typeof(System.Windows.Forms.Design.FolderNameEditor), typeof(System.Drawing.Design.UITypeEditor))] [Optional, NotChecked][DefaultValue("")]public string OutputDirectory { get{return Directory;}set{if (value.EndsWith("\\")) value = value.Substring(0, value.Length -1);Directory = value;} }
</script>

5.在test.cst中写些函数来完成将数据库架构传递给模板的工作;

<script runat="template">//生成实体Entity类
private void GenerateEntityClasses(){CodeTemplate Template =new EntityTemplate();foreach(TableSchema table in this.SourceDatabase.Tables){string FileDirectory = OutputDirectory +"\\"+ table.Name +".cs";//生成模板Template.SetProperty("Table",table);//文件输出Template.RenderToFile(FileDirectory,true);Debug.WriteLine(FileDirectory +" 创建成功.");}}
</script>

6.在test.cst中调用刚刚写好的函数;

 
<%
//创建实体层Entity类
this.GenerateEntityClasses();Debug.WriteLine("OK");
%>
 

7.设置我们要导出的数据库和输出目录;

a.点击CodeSmith主窗体右上角Schema Explorer面板,点击图标添加要连接的数据库,填写三个参数:

Name(要连接的数据库名字),Provider Type(sql server数据库选择SqlSchemaProvider),Connection String(可点击后面的按钮,填写数据库所在服务器名字或ip、登录方式和数据库名)

测试连接成功后,创建数据库成功。

b.点击CodeSmith主窗体右下角Properities面板中SourceDatabase属性栏右侧的…按钮,弹出数据库设置对话框,选择创建好的test数据库;

c.点击CodeSmith主窗体右下角Properities面板中OutputDirectory属性栏右侧的…按钮,选择目标文件输出目录。

 

8.回到test.cst页面,点击Generate自动生成代码成功后,可到输出目录中查看到所有表的实体类文件。

注:也可以在entity.cst模板文件中选择某个table单独生成实体类。

 

更多CodeSmith知识参照:http://terrylee.cnblogs.com/archive/2005/12/28/306254.aspx



转载于:https://www.cnblogs.com/jjdmk/p/4435976.html


http://chatgpt.dhexx.cn/article/Cm9AQyDH.shtml

相关文章

CodeSmith模板

CodeSmith的模板默认是放在用户目录下的&#xff0c;在安装的时候可以自定义&#xff1a; D:\Users\admin\Documents\CodeSmith Generator\Templates 上次放在c盘电脑重装就没有了&#xff0c;好多模板都丢失了&#xff0c;于是又得重新写&#xff0c;为了方便就记到博客园里吧…

CodeSmith连Oracle

据说CodeSmith连Oracle特别麻烦&#xff0c;什么WIN7下不行&#xff0c;64位下不行。之前有个同事为了用上CodeSmith&#xff0c;还特地装了个XP虚拟机。 其实&#xff0c;还是那个连接串的问题。 操作系统64位&#xff0c;就要用64位的驱程。但我们机器上装的是oracle 10g&a…

codesmith mysql 注释_完美解决CodeSmith无法获取MySQL表及列Description说明注释的方案...

问题描述&#xff1a; CodeSmith是现在比较实用的代码生成器&#xff0c;但是我们发现一个问题&#xff1a; 使用CodeSmith编写MySQL模板的时候&#xff0c;会发现一个问题&#xff1a;MySQL数据表中的列说明获取不到&#xff0c;也就是column.Description。如图&#xff1a; 我…

codesmith mysql 模板_CodeSmith for MySQL template

对于.NET平台上的代码生成器来说&#xff0c;codesmith是一个非常好的选择。 以前在学院实验室用的都是SQL server数据库&#xff0c;老师给的一套codesmith模板用来生成model/DAL/BLL很是方便。 不过后来放弃SQL server 投入MySQL之后&#xff0c;刚开始都是手写SQL&#xff0…

如何使用CodeSmith批量生成代码(原创系列教程)

用它完成批量代码生成的工作啦. 下面我会一步步的解释如何用CodeSmith实现预期的结果的,事先声明一下,在此只做一个简单的Demo,并不详细的讲解CodeSmith各个强大的功能,有兴趣的朋友可以打开CodeSmith的帮助文档了解.我只做个抛砖引玉,希望能激起大家更多思想的火花~ 先看看C…

codesmith生成SQLSERVER实体(带注释)

记录用codesmith生成SQLSERVER数据库实体的一个模板&#xff0c;具体链接数据库和使用方式&#xff0c;大家可以百度&#xff0c;有非常多的资料&#xff0c;只记录一个模板&#xff1a; <% CodeTemplate Language"C#" TargetLanguage"C#" Debug"…

mysql codesmith_CodeSmith MySql

CodeSmith MySql (2012-08-22 10:41:49) 标签&#xff1a; 杂谈 安装&#xff1a; mysql-connector-net-6.3.7.msi 否则在CodeSmith中链接数据库时提示需要框架程序。 connect string&#xff1a; 正确&#xff1a;DatabaseXXX;Data SourceXXX;User IdXXX;PasswordXXX;portXXX …

CodeSmith模板代码生成实战详解

为了提高开发效率&#xff0c;节约开发时间&#xff0c;我们采用了codesmith根据自定义模板&#xff0c;生成代码功能。让单表的增删改查功能从数据访问层到ui展示层一键批量生成。下面就开始codeSmith模板编写。 官网地址&#xff1a;http://www.codesmithtools.com 下载地址&…

CodeSmith 简单使用和常用模板

1、简介 CodeSmith 是一种基于模板的代码生成工具&#xff0c;它使用类似于 ASP.NET的语法来生成任意类型的代码或文本。 2、软件布局 整体布局和visual studio系列相似&#xff0c;用过VS开发对此软件布局会很熟悉&#xff0c;加上模板语句类似ASP.NET对.NET开发人员相对友…

CodeSmith介绍

什么是CodeSmith&#xff1f;从字面上直译可以看作“代码工匠”。这倒是个很拟人化的名称&#xff0c;顾名思义&#xff0c;CodeSmith的目标就是根据模板生成规范可用的代码&#xff0c;为程序员减轻工作负担。程序员是软件开发团队中的最小单位&#xff0c;有什么任务都只能自…

waf绕过详解

目录 waf防护原理讲解 目录扫描绕过waf 手工注入绕过waf sqlmap注入绕过waf 编写sqlmap绕过waf脚本 过waf一句话编写讲解 菜刀连接绕过waf webshell上传绕过waf 提权绕过waf waf绕过原理详解 了解waf防护原理 查看waf防护位置 熟悉防护规则 了解防护机制 查看拦截…

WAF与网络防火墙的区别在哪?

WAF是英文Web Application Firewall的简称&#xff0c;也称为网站应用级入侵防御系统或Web应用防火墙&#xff0c;是通过执行一系列针对HTTP/HTTPS的安全策略来专门为Web应用提供保护的一款产品。 网络防火墙是一种用来加强网络之间访问控制的特殊网络互联设备。计算机流入流出…

WAF(Web应用层防火墙)了解学习

WAF---Web应用层防火墙了解学习 WAF是什么WAF预防的攻击类型WAF部署方式WAF安全模式开放Web应用安全项目&#xff08;OWASP&#xff09;WAF和DDosWAF测试WAF和传统防火墙的区别总结 参考文档: 安全文章相关Web应用防火墙WAF简介 WAF是什么 WAF全称叫Web Application Firewall…

什么是 Web 应用防火墙(WAF)?

当下时候&#xff0c;网络攻击和针对网站的攻击与日俱增。同时&#xff0c;在我们的日常生活中&#xff0c;安全的重要性也迅速提升。因此&#xff0c;保证在线上世界的安全变得越来越重要。更重要的是&#xff0c;保护你的网站和所存储的数据的安全。所以&#xff0c;我们将介…

【网络安全】如何在Apache 安装开源 WAF

说明&#xff1a; 本文以Windows环境下的Apache安装mod_security为例&#xff0c; 介绍开源WAF产品的安装使用。 http://www.modsecurity.cn/ https://github.com/SpiderLabs/ModSecurity一、WAF基本介绍 WAF全称Web Application Firewall&#xff0c;即Web应用防火墙。Web应用…

WAF详解及WAF绕过

waf&#xff08;web application firewall&#xff09;: 原理&#xff1a; web应用防火墙&#xff0c;一款集网站内容安全防护、网站资源安全防护及流量保护功能为一体的服务器工具。为用户提供实时网站安全防护&#xff0c;避免各类针对网站的攻击带来的危害。&#xff08;核心…

waf入门

文章目录 waf入门什么是wafwaf一般都有哪些功能WAF部署模式WAF工作模式 规则引擎原理WAF动作WAF规则与报表WAF特征 waf入门 什么是waf Web应用防护系统&#xff08;也称为&#xff1a;网站应用级入侵防御系统。英文&#xff1a;Web Application Firewall&#xff0c;简称&…

WAF识别软件(WAFW00F)以及WAF绕过

责任声明&#xff1a; 本文章仅供学习交流使用&#xff0c;如有利用进行非法行为 上传者不承担任何责任&#xff0c;使用者后果自负 WAF防护分析 什么是WAF&#xff1f; Web应用防护系统分为两种&#xff1a;软件与硬件 安全公司内部的为硬件&#xff0c;个人或小企业为软件&…

IPS和WAF区别

写在前面&#xff1a; “前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站。” 前言 - 床长人工智能教程 WAF与IPS的区别总结 谁是最佳选择&#xff1f; Web应用防护无疑是一个热门话题。…

waf详解

文章目录 一、waf分类二、waf的工作原理 前言&#xff1a; 在实际的渗透测试过程中&#xff0c;经常会碰到网站存在WAF的情况。网站存在WAF&#xff0c;意味着我们不能使用安全工具对网站进行测试&#xff0c;因为一旦触碰了WAF的规则&#xff0c;轻则丢弃报文&#xff0c;重则…