zoukankan      html  css  js  c++  java
  • python自动化测试-D7-学习笔记之一(sql补充内容)

    # sql 注入:原理是利用了引号
    # sql语句中用了引号,可以构造 1=1这类永远为真 且合格的sql语句
    # 例如 "select * from bt_stu where real_name='%s' and sex = %s"%(name,sex) 可以把name 的字符串写成 'or '1'='1
    # sql语句就变成了 select * from bt_stu where real_name =''or'1'='1' and sex = 0 直接把所有内容都打印出来了
    # 或者 name 字符串构造成 name = " ' ;show tables;' -- "
    # sql语句就变成了 select * from bt_stu where real_name ='';show tables; '-- and sex = 0
    # 同理,也可以把show tables 语句改成 删除 修改等操作
    # 所以为了防止sql注入,我们写sql语句的时候,需要把%s的引号去掉
    # 例如:sql = "select * from bt_stu where real_name=%s;",name

    # 为了防止sql注入,那么我的op_mysql()的函数,参数则需要修改,用可变参数
    # def test(a,b):
    # pass
    #
    # li = [1,2]
    # d = {'la':'lala',
    # 'li':'lili'}
    # test(*li) # 可变参数 一一对应,1传给a,2传给b
    # test(**d) # 可变参数 一一对应,la传给a,li传给b

    import pymysql,json
    import conn
    def op_mysql(sql,*data,
    host=conn.MYSQL_HOST,
    user=conn.MYSQL_USER,
    password=conn.MYSQL_PASSWORD,
    db=conn.MYSQL_DB,
    port=conn.MYSQL_PORT,
    charset=conn.MYSQL_CHARSET
    ):

    conn = pymysql.connect(
    host=host,
    user=user,
    password=password,
    db=db,
    port=port,
    charset=charset
    )
    cur = conn.cursor(cursor=pymysql.cursors.DictCursor)
    cur.executemany(sql,data)
    sql_start = sql[:6].upper()

    if sql_start == 'SELECT':
    res_list = cur.fetchall()
    res = json.dumps(res_list,ensure_ascii=False)
    else:
    conn.commit()
    res = 'Exe Success'
    return res

    name = 'admin'
    money = 10000
    sql = "select * from user WHERE username = %s AND money = %s;"
    data = [name,money]
    res=op_mysql(sql,data)
    print(res)
    sql1 = 'insert into seq (blue,red,date) values (%s,%s,%s)'
    all_res = [
    ['16','01,02,03,05,09,06','2018-01-28'],
    ['15','01,02,03,05,09,06','2018-01-28'],
    ['14','01,02,03,05,09,06','2018-01-28'],
    ['13','01,02,03,05,09,06','2018-01-28'],
    ['13','01,02,03,05,09,06','2018-01-28'],
    ['13','01,02,03,05,09,06','2018-01-28'],
    ['13','01,02,03,05,09,06','2018-01-28'],
    ['13','01,02,03,05,09,06','2018-01-28'],
    ['13','01,02,03,05,09,06','2018-01-28'],
    ['13','01,02,03,05,09,06','2018-01-28'],
    ['13','01,02,03,05,09,06','2018-01-28'],
    ['13','01,02,03,05,09,06','2018-01-28'],
    ]
    res=op_mysql(sql1,*all_res) # 如果不加 * 调用函数的时候,因为函数里写的是 *data data本身是一个元组,不加*传进去后,打印出来的data是一个三维的([[]],[[]],[[]])
    # 加了 * 之后是把参数一个个的传进去,所以调用函数的时候,data变成了二维数组
    print(res)
    # 修改,删除
  • 相关阅读:
    nginx 负载均衡配置
    nginx 配置优化详解
    duilib -- Label控件的bug(转载)
    Duilib实现GroupBox控件
    Duilib动画按钮实现(转载)
    Duilib中Webbrowser事件完善使其支持判断页面加载完毕
    Duilib实现圆形头像控件
    duilibutilsutils.h(251) : error C2504: “VARIANT”: 未定义基类
    软件项目版本号的命名规则及格式
    c++中char*wchar_t*stringwstring之间的相互转换
  • 原文地址:https://www.cnblogs.com/blackbird0423/p/8394751.html
Copyright © 2011-2022 走看看