golang手撸模板解析器

因需求调研模板引擎解析

有点粗暴,暂时只有这个想法了~

模板文件(html)

{sdsn:arclist menuid='11'}
	<a href='[field:id/]'>[field:title/]</a>
{/sdsn:arclist}

读取html文件

cwd, _ := os.Getwd()
content, err := os.ReadFile(cwd + "/template/index.html")
if err != nil {
	fmt.Println("Error reading file:", err)
	return
}
// 删除换行符
htmlStr := strings.ReplaceAll(strings.ReplaceAll(string(content), "\n", ""), "\r", "")

正则解析标签

//匹配标签
re := regexp.MustCompile(`\{\s*sdsn:arclist(.+?)\}(.+?)\{\s*/sdsn:arclist\s*\}`)

//匹配标签中的所属栏目id
reMenuId := regexp.MustCompile(`typeid=['"](.*?)['"]`)

//匹配标签中的字段
reField := regexp.MustCompile(`\[\s*field:(.+?)\s*/\]`)

替换替换标签字符串

这里需要考虑从数据库查出的数据,需要对其转化成map格式,然后根据匹配到k 使用map取值,并且对其替换

for _, match := range re.FindAllStringSubmatch(htmlStr, -1) {
	// 查询列表数据
	var articles []structs.Article
	var temHtml string
	sql := utils.DB.Debug().Table("article")
	if len(reMenuId.FindStringSubmatch(match[1])) > 0 {
		sql = sql.Where("menu_id = ?", reMenuId.FindStringSubmatch(match[1])[1])
	}
	sql.Find(&articles)
	for i := 0; i < len(articles); i++ {
		liStr := match[2]
		for _, f := range reField.FindAllStringSubmatch(match[2], -1) {
			articlesMap, _ := utils.ToMap(articles[i], "json")
			liStr = strings.ReplaceAll(liStr, f[0], fmt.Sprintf("%v", articlesMap[f[1]]))
		}
		temHtml = temHtml + liStr
	}
	htmlStr = strings.ReplaceAll(htmlStr, match[0], temHtml)
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现PE文件解析器的步骤如下: 1. 读取PE文件头,获取文件头信息。 2. 读取节表头,获取节表信息。 3. 读取导入表、导出表、重定位表等其他表,获取相关信息。 4. 解析每个节的数据,获取代码、数据等信息。 5. 根据节表中的信息,将PE文件中的代码、数据等部分映射到内存中。 6. 解析导入表,获取导入的函数信息,并进行符号解析。 7. 解析导出表,获取导出函数信息,并生成符号表。 8. 处理重定位表,修正代码中的地址。 9. 实现其他功能,如获取PE文件中的资源信息、版本信息等。 下面是一个简单的golang实现PE文件解析器的代码示例: ```go package main import ( "debug/pe" "fmt" "os" ) func main() { if len(os.Args) != 2 { fmt.Println("Usage: pe-parser <filename>") return } file, err := os.Open(os.Args[1]) if err != nil { fmt.Println("Failed to open file:", err) return } defer file.Close() peFile, err := pe.NewFile(file) if err != nil { fmt.Println("Failed to parse PE file:", err) return } fmt.Println("PE Header Info:") fmt.Printf("\tMachine: %s\n", peFile.FileHeader.Machine) fmt.Printf("\tNumber of Sections: %d\n", peFile.FileHeader.NumberOfSections) fmt.Printf("\tSize of Optional Header: %d\n", peFile.FileHeader.SizeOfOptionalHeader) fmt.Println("\nSection Table Info:") for _, section := range peFile.Sections { fmt.Printf("\tName: %s\n", section.Name) fmt.Printf("\tVirtual Address: %d\n", section.VirtualAddress) fmt.Printf("\tVirtual Size: %d\n", section.VirtualSize) fmt.Printf("\tRaw Size: %d\n", section.Size) fmt.Printf("\tOffset: %d\n", section.Offset) fmt.Println() } } ``` 该代码使用了golang标准库中的`debug/pe`包来实现PE文件解析器,可以获取PE文件头信息和节表信息。你可以根据需要扩展代码以支持更多功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值