codesmith mysql 模板_CodeSmith for MySQL template

article/2025/9/15 19:28:44

对于.NET平台上的代码生成器来说,codesmith是一个非常好的选择。

以前在学院实验室用的都是SQL server数据库,老师给的一套codesmith模板用来生成model/DAL/BLL很是方便。

不过后来放弃SQL server 投入MySQL之后,刚开始都是手写SQL,还是很痛苦的。

再后来又去找MySQL codesmith模板,这个对应的资料就不多了。不过最后还是找到了一套不错的,凑合能用。起初也懒,codesmith语法不熟,就没想过去修改一下了。

最近又要用到这套东西,于是决定还是去修改一番,更便于使用。

这个文章就主要讲一下修改过程,顺便说一下codesmith的简单语法。

先说一下操作步骤:

把模板的文件夹扔到codesmith模板文件的路径下,接着打开Codesmith,找到刚扔过去的文件夹,选择Main.cst,右键-execute-选择对应的MySQL库-选中表。

(注:codesmith连接MySQL有问题的话,

移步这里解决 CodeSmith 连接MySQL数据库报“can’t find .net framework data provider”

如下图:

0818b9ca8b590ca3270a3433284dd417.png

然后点击Generate就能顺利生成model/dal/bll了。

生成代码结构如下:

0818b9ca8b590ca3270a3433284dd417.png

这样操作没什么问题,顺利生成了我们要的model/dal/bll了,然后….我懒嘛。 每次都要把表一个个选一次,麻不麻烦啊。然后就想了,能不能改一下模板呢。于是便开始google相关资料了。找到了几个相关文章,参考这就开始改造了。 先看看原来的Main.cst里面写了撒。

这一段基本就是在声明选项以及引用命名空间,表现出来的便是我们看到的下图:

0818b9ca8b590ca3270a3433284dd417.png

Models model = this.Create();

model.ModelsNamespace = this.RootNamespace+".Model";

model.TargetTable = this.SourceTable;

model.RenderToFile(this.OutputDirectory+"Model/"+model.GetFileName(),true);

DAL dal = this.Create();

dal.TargetTable = this.SourceTable;

dal.ModelsNamespace = model.ModelsNamespace;

dal.DALClassNameSurfix = "DAL";

dal.DALNamespace =this.RootNamespace+".DAL";

dal.RenderToFile(this.OutputDirectory+"DAL/"

+dal.GetFileName(),true);

BLL bll = this.Create();

bll.ModelsNamespace = model.ModelsNamespace;

bll.DALClassNameSurfix = dal.DALClassNameSurfix;

bll.DALNamespace = dal.DALNamespace;

bll.BLLClassNameSurfix = "BLL";

bll.BLLNamespace = this.RootNamespace+".BLL";

bll.TargetTable = this.SourceTable;

bll.RenderToFile(this.OutputDirectory+"BLL/"

+bll.GetFileName(),true);

Response.Write("ok,see "+this.OutputDirectory);

%>

这一段就是我们点击Generate之后执行的代码,基本功能就是调用

DBMad.Models.cst,DBMad.DAL.cst,DBMad.BLL.cst。

因为在上面声明数据源的时候,使用了SchemaExplorer.TableSchema,导致我们选择表的时候不能多选。代码如下:

前面一部分还是一样的声明,

这一段代码便是获取刚得到的表集合,遍历集合然后依次调用之前的单表生成模板。

到这里差不多已经完成了我要的效果,选择多表,实现一次生成所有的表对应的model/dal/bll。

这个效果基本就是我要的了,但是后来又发现,model里面的字段居然没有注释,我在建表的时候写了字段注释的呀。

打开model的cst文件之后发现,模板并没有做注释这个工作。

代码如下:

using System;

using System.Collections.Generic;

using System.Text;

namespace

{

[Serializable()]

public class

{

private _;

public

{

get { return _; }

set { _ = value; }

}

}

}

获取表中字段名使用的是GetPropertyName(column),咦,在哪实现了这个东西呢?回去翻一下文件,哦,还有一个ToolsCodeTemplate.cs文一直没管呢。

果然,GetPropertyName(column)在这里。

public string GetPropertyName(ColumnSchema column)

{

return GetNameFromDBFieldName(column);

}

public string GetNameFromDBFieldName(ColumnSchema column)

{

return column.Name;

}

读取列名就是这么简单,那么我们对应写一个函数读取一下列注释,然后再model里面调用一下不好了。

又查了一下资料,

public string GetColumnComment(ColumnSchema column)

{

return column.Description;

}

嗯,理论上这样是可以的…

然而,我想多了。倒腾了好久,这个属性值都是空的…

google了一圈之后发现,原来是SchemaExplorer.MySQLSchemaProvider.dll 里面压根没实现读取列注释的实现….

不过也有对应的解决方法:

把DLL替换一下就好了。

注:

模板会把MySQL的表名前三个字符截取掉,建议把表明设置为tbl开头,或者自行修改模板文件。

想让字段注释生效记得替换SchemaExplorer.MySQLSchemaProvider.dll(替换前记得备份!)


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

相关文章

如何使用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;重则…

waf测试

waf简介 WAF防火墙其实就是Web Application Firewall&#xff0c;是一个web应用防护系统。企业等用户一般采用防火墙作为安全保障体系的第一道防线。WAF工作在应用层&#xff0c;因此对Web应用防护具有先天的技术优势。基于对Web应用业务和逻辑的深刻理解&#xff0c;WAF对来自…

云WAF概述

云WAF&#xff08;Web应用防火墙&#xff09;是WAF的另一种表现形态&#xff0c;它将WAF的功能在云端进行实现。只需要把域名的解析权交给云WAF&#xff0c;它就可以利用DNS调度技术&#xff0c;改变网络流量的原始流向&#xff0c;将网络流量牵引到云端的WAF上&#xff0c;云端…

WAF的原理

一.WAF的原理 WAF是Web应用防火墙&#xff08;Web Application Firewall&#xff09;的简称&#xff0c;对来自Web应用程序客户端的各类请求进行内容检测和验证&#xff0c;确保其安全性与合法性&#xff0c;对非法的请求予以实时阻断&#xff0c;为Web应用提供防护&#xff0c…

WAF介绍

一、WAF产生的背景&#xff1a; 过去企业通常会采用防火墙&#xff0c;作为安全保障的第一道防线&#xff1b;当时的防火墙只是在第三层&#xff08;网络层&#xff09;有效的阻断一些数据包&#xff1b;而随着web应用的功能越来越丰富的时候&#xff0c;Web服务器因为其强大的…