WEB开发网
开发学院数据库MySQL 最佳措施 全面解决MySQL网络安全问题 阅读

最佳措施 全面解决MySQL网络安全问题

 2008-08-30 11:07:32 来源:WEB开发网   
核心提示: 你还可以使用REQUIRE SUBJECT来指定一个特定的客户端证书来访问数据库,GRANTALLPRIVILEGESONssl_only_db.*to'abc'@'%'IDENTIFIEDBY"password!"REQUIRESUBJ

你还可以使用REQUIRE SUBJECT来指定一个特定的客户端证书来访问数据库。

  GRANTALLPRIVILEGESONssl_only_db.*to'abc'@'%'
  IDENTIFIEDBY"password!"
  REQUIRESUBJECT"/C=US/ST=NewYork/L=Albany/O=WidgetsInc./CN=client-ray.
  example.com/emailAddress=raymond@example.com";

也许你并不关心使用的是什么客户许可,而仅仅关心的是你的证书。那么你可以使用REQUIRE ISSUER来实现:

  GRANTALLPRIVILEGESONssl_only_db.
  *to'abc'@'%'IDENTIFIEDBY"password!"
  REQUIREISSUER
  "/C=US/ST=New+20York/L=Albany/O=WidgetsInc./CN=cacert.example.
  com/emailAddress=admin@example.com";

SSL还可以直接通过密码进行加密。可以使用REQUIRE CIPHER设置密码。

  GRANTALLPRIVILEGESONssl_only_db.
  *to'abc'@'%'IDENTIFIEDBY"password!"
  REQUIRECIPHER"EDH-RSA-DES-CBC3-SHA";

上面使用了GRANT命令对用户权限进行设置。而这些信息都是保存在授权表中,这些表是安全系统的心脏。在这些表中保存了每一个用户和客户机所具有的权限。如果正确地操作这些表,将会对数据库的安全起到积极的作用,而如果使用不慎,将是非常危险的。

下面让我们来看看MySQL中的最要的5个授权表。

user

用户表保存了用户的权限和被加密的密码。这个表负责确定哪些用户和客户机可以连接到服务器上。

host

这个表为每一个客户机分配权限,它并不考虑用户的权限。MySQL在确定是否接收还是拒绝一个连接时,首先考虑的是user表。而使用GRANT或REVOKE命令并不影响host表,我们可以通过手工方式修改这个表中的内容。

上一页  1 2 3 4 5  下一页

Tags:最佳 措施 全面

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接