给我代码好嘛,第三项我选择数据库

时间: 2024-04-15 19:29:44 浏览: 14
当然,以下是一个使用Go语言和MySQL数据库实现IP封堵和解封的代码示例: ```go package main import ( "database/sql" "fmt" "log" "net/http" "github.com/gin-gonic/gin" _ "github.com/go-sql-driver/mysql" ) type IP struct { ID int Addr string } var db *sql.DB func main() { // 连接数据库 err := connectDB() if err != nil { log.Fatal(err) } // 创建IP黑名单表 err = createTable() if err != nil { log.Fatal(err) } // 初始化路由 router := gin.Default() router.LoadHTMLGlob("templates/*") router.GET("/", getIndex) router.POST("/block", blockIP) router.POST("/unblock", unblockIP) // 启动服务器 err = router.Run(":8080") if err != nil { log.Fatal(err) } } func connectDB() error { var err error db, err = sql.Open("mysql", "username:password@tcp(localhost:3306)/database") if err != nil { return err } err = db.Ping() if err != nil { return err } fmt.Println("Connected to database") return nil } func createTable() error { createTableSQL := ` CREATE TABLE IF NOT EXISTS ip_blacklist ( id INT AUTO_INCREMENT PRIMARY KEY, addr VARCHAR(45) NOT NULL UNIQUE );` _, err := db.Exec(createTableSQL) return err } func getIndex(c *gin.Context) { var ips []IP rows, err := db.Query("SELECT * FROM ip_blacklist") if err != nil { c.HTML(http.StatusInternalServerError, "error.html", gin.H{"error": err.Error()}) return } defer rows.Close() for rows.Next() { var ip IP err := rows.Scan(&ip.ID, &ip.Addr) if err != nil { c.HTML(http.StatusInternalServerError, "error.html", gin.H{"error": err.Error()}) return } ips = append(ips, ip) } c.HTML(http.StatusOK, "index.html", gin.H{"ips": ips}) } func blockIP(c *gin.Context) { ip := c.PostForm("ip") _, err := db.Exec("INSERT INTO ip_blacklist (addr) VALUES (?)", ip) if err != nil { c.HTML(http.StatusInternalServerError, "error.html", gin.H{"error": err.Error()}) return } c.Redirect(http.StatusSeeOther, "/") } func unblockIP(c *gin.Context) { ip := c.PostForm("ip") _, err := db.Exec("DELETE FROM ip_blacklist WHERE addr = ?", ip) if err != nil { c.HTML(http.StatusInternalServerError, "error.html", gin.H{"error": err.Error()}) return } c.Redirect(http.StatusSeeOther, "/") } ``` 请注意,上述代码示例仅供参考,您需要根据实际情况进行适当的修改和优化。确保替换`username`、`password`和`database`为自己的数据库信息,并在相应目录下创建正确的HTML模板文件(index.html和error.html)。还需要安装`gin`和`go-sql-driver/mysql`库,可以使用以下命令进行安装: ``` go get github.com/gin-gonic/gin go get github.com/go-sql-driver/mysql ``` 希望对您有所帮助!如果有任何问题,请随时提问。

相关推荐

最新推荐

recommend-type

数据库课程设计 报告+程序代码

数据库课程设计 报告+程序代码 数据库课程设计 报告+程序代码 数据库课程设计 报告+程序代码 数据库课程设计 报告+程序代码
recommend-type

数据库原理与设计第三章关系数据模型思维导图

为了方便数据库的学习,在学完这一章过后将重要的知识点汇总,通过绘制思维导图的方式进行记录,通过每一小节的重点绘制,能够有很清楚的思路进行统一性的学习,欢迎大家做出改正噢
recommend-type

MyBatis-plus+达梦数据库实现自动生成代码的示例

主要介绍了MyBatis-plus+达梦数据库实现自动生成代码的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

java使用influxDB数据库的详细代码

主要为大家介绍了java使用influxDB数据库的详细代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

土地规划大数据库类型代码.doc

土地规划数据库类型代码。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

用Spring boot和vue写一个登录注册界面

好的,这是一个比较常见的技术问题,我可以为您提供一些参考资料和思路。首先,您可以使用Spring Boot作为后端框架来处理用户认证和注册的逻辑,比如使用Spring Security实现用户登录认证。同时,您还需要设计相应的数据模型和数据库表结构来存储用户信息。在前端方面,您可以使用Vue.js作为框架来构建登录注册页面,使用Axios来发起API请求并和后端进行交互。当然,在实现过程中,还需要考虑一些具体细节,比如数据校验、安全性和用户体验等方面。希望这些信息能够帮助到您。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。