设为首页 收藏本站
查看: 1723|回复: 0

[经验分享] 一个PYTHON的CGI

[复制链接]

尚未签到

发表于 2015-4-23 05:59:15 | 显示全部楼层 |阅读模式
本来想用mod_python的,但是老是装不上,就直接用CGI了,这个程序的目的是从数据中查询校友的名字并显示出链接相片(很YY啊),被他们拿来寻找美女了……呵呵
#!/usr/bin/python
# -*-coding:UTF-8-*-#
import MySQLdb
import urllib
import cgi
print "Content-type: text/html\n\n";
db = MySQLdb.connect(user="xxx",host="xxx",port=3306,passwd="xxx",db="xxx")
db.charset='utf-8'
c = db.cursor()
c.execute("SET NAMES 'utf8'")
#header
print '''

xxx学生名单速查




#content
{
    padding: 10px 0px 10px 0px;
    width: 80%;
    margin: 0px 10% 0px 10%;
    border-left-width: 3px;
    border-left-style: solid;
    border-left-color: Red;
    border-top-width: 1px;
    border-top-style: solid;
    border-top-color: Red;
    font-size: medium;
    font-family: Verdana, Geneva, Arial, Sans-Serif;
}
#title
{
    padding: 10px 10px 10px 10px;
    font-weight:bold;
    margin: 10px 0 30px 5%;
    border-left-width: 2px;
    border-bottom-width: 1px;
    border-left-style: solid;
    border-bottom-style: solid;
    border-left-color: Red;
    border-bottom-color: Red;
}
.post
{
    padding: 5px;
    margin: 0px 0px 10px 5%;
    border-top-width: 1px;
    border-bottom-width: 1px;
    border-left-width: 2px;
    border-top-style:dashed;
    border-bottom-style:dashed;
    border-left-style: solid;
    border-top-color: Red;
    border-bottom-color: Red;
    border-left-color: Red;
    display: block;
}
.post .headitem
{
    margin: 0px 0px 5px 5px;
    display:block;
}
.item
{
    margin: 0px 0px 0px 5px;
    display: inline;
}
a
{
    text-decoration:none;
    border:solid Red 1px;
    color:Red;
}
a:hover
{
    color:White;
    background-color:Red;
}






xxx学生名单速查
本程序为本人学习作品,部分资料从网上收集得来,供各位同学学习之用。由此带来的一切法律责任和版权纠纷,本人盖不负责。如果您认为该程序侵犯了您的合法权利,请与本人联系。
'''

#content_table
print '''


  或 执行“按例查询”(通配符:“%”)
  
   
      
        查询
        请输入查询的值
      
   
   
      
        学号
        
      
      
        姓名
        
      
      
        生日
        
      
   
  
  
  
  
  
'''

#content_return value
bs = ['\'','\/','\\']
form = cgi.FieldStorage()
err = 0
if not (form.has_key("xh") or form.has_key("xm") or form.has_key("bd")):
    print "等待您的查询 DSC0000.gif "
else:
    strsql = 'select xh,xm,bd from student where '
    strsep = ''
    if form.has_key("xh"):
        for strbs in bs:
            if(form["xh"].value.find(strbs)!=-1):
                err = 1
                break
        strsql = strsql.__add__("xh like '")
        strsql = strsql.__add__(form["xh"].value)
        strsql = strsql.__add__("'")
        strsep = ' and '
    if form.has_key("xm"):
        for strbs in bs:
            if(form["xm"].value.find(strbs)!=-1):
                err = 1
                break
        strsql = strsql.__add__(strsep)
        strsql = strsql.__add__("xm like '")
        strsql = strsql.__add__(form["xm"].value)
        strsql = strsql.__add__("'")
        strsep = ' and '
    if form.has_key("bd"):
        for strbs in bs:
            if(form["bd"].value.find(strbs)!=-1):
                err = 1
                break
        strsql = strsql.__add__(strsep)
        strsql = strsql.__add__("bd like '")
        strsql = strsql.__add__(form["bd"].value)
        strsql = strsql.__add__("'")
    strsql = strsql.__add__(' limit 0,30')
    if(err==0):
        c.execute(strsql)
        stulist = c.fetchall()
        print ''
        for xh,xm,bd in stulist:
            print "" % xh
            print "学号:%s" % xh
            print ''
            print "姓名:%s" % xm
            print ''
            print "出生日期:%s" % bd
            print ''
        print ''
    else:
        print '你要干嘛?'
    c.close()
    db.close()

print ''

print '''powered by qinchuan


'''

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-59699-1-1.html 上篇帖子: Python中的数组 下篇帖子: ruby/python/java全覆盖的Selenium-Webdriver系列教程(2)————浏览器的简单操作
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表