• <small id='brZ6e'></small><noframes id='brZ6e'>

  • <i id='brZ6e'><tr id='brZ6e'><dt id='brZ6e'><q id='brZ6e'><span id='brZ6e'><b id='brZ6e'><form id='brZ6e'><ins id='brZ6e'></ins><ul id='brZ6e'></ul><sub id='brZ6e'></sub></form><legend id='brZ6e'></legend><bdo id='brZ6e'><pre id='brZ6e'><center id='brZ6e'></center></pre></bdo></b><th id='brZ6e'></th></span></q></dt></tr></i><div id='brZ6e'><tfoot id='brZ6e'></tfoot><dl id='brZ6e'><fieldset id='brZ6e'></fieldset></dl></div>
      • <bdo id='brZ6e'></bdo><ul id='brZ6e'></ul>
      <tfoot id='brZ6e'></tfoot>

        <legend id='brZ6e'><style id='brZ6e'><dir id='brZ6e'><q id='brZ6e'></q></dir></style></legend>

        密码保护 Python

        Password Protection Python(密码保护 Python)

          <legend id='jQcZS'><style id='jQcZS'><dir id='jQcZS'><q id='jQcZS'></q></dir></style></legend>
          <i id='jQcZS'><tr id='jQcZS'><dt id='jQcZS'><q id='jQcZS'><span id='jQcZS'><b id='jQcZS'><form id='jQcZS'><ins id='jQcZS'></ins><ul id='jQcZS'></ul><sub id='jQcZS'></sub></form><legend id='jQcZS'></legend><bdo id='jQcZS'><pre id='jQcZS'><center id='jQcZS'></center></pre></bdo></b><th id='jQcZS'></th></span></q></dt></tr></i><div id='jQcZS'><tfoot id='jQcZS'></tfoot><dl id='jQcZS'><fieldset id='jQcZS'></fieldset></dl></div>

            <tbody id='jQcZS'></tbody>

          <small id='jQcZS'></small><noframes id='jQcZS'>

              <tfoot id='jQcZS'></tfoot>
                • <bdo id='jQcZS'></bdo><ul id='jQcZS'></ul>
                  本文介绍了密码保护 Python的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我有一个小型 python 程序,将由一小群人(<15 人)在本地使用.但为了问责,我想在程序开始时进行简单的用户名+密码检查(不't需要超级安全).供您参考,我只是一个初学者,这是我第一次尝试它.当我四处搜索时,我发现python有用于加密的passlib.但即使在看了之后,我仍然不确定如何实现我的加密.所以,我想知道一些事情.

                  I have a small python program which will be used locally by a small group of people (<15 people).But for accountability, i want to have a simple username+password check at the start of the program ( doesn't need to be super secure).For your information, I am just a beginner and this is my first time trying it.When i search around, i found that python has passlib for encryption. But even after looking though it i am still not sure how to implement my encryption.So, there are a few things that i want to know.

                  1. 如何在本地存储用户的密码?我目前知道的唯一方法是创建一个文本文件并从中读取/写入,但这会破坏加密的整个目的,因为人们可以打开文本文件并从那里读取它.
                  2. hash & 是什么意思?盐意味着加密,它是如何工作的?(简单的解释就可以了.)
                  3. 实施用户名和密码检查的推荐方法是什么?

                  对于这些愚蠢的问题,我深表歉意.但如果您能回答我的问题,我将不胜感激.

                  I am sorry for the stupid questions. But i will greatly appreciate if you could answers my question.

                  推荐答案

                  import getpass
                  import pickle
                  import hashlib
                  from os import path
                  
                  def Encryption(data):
                      return hashlib.sha512(data).hexdigest()
                  
                  ## First we check if the database exists.
                  if path.isfile('database.db'):
                      with open('database.db', 'rb') as fh:
                          db = pickle.load(fh)
                  
                  ## If it doesn't, we will create one.
                  else:
                      ## First we create the desired variable.
                      db = {'torxed' : Encryption('wham'), 'someoneelse' : Encryption('pass')}
                      ## Then we open a filehandle to it.
                      with open('database.db', 'wb') as fh:
                          ## And then we dump the variable into the filehandle.
                          ## This will keep the variable intact between sessions,
                          ## meaning the next time you start your script, the variable will look the same.
                          pickle.dump(db, fh)
                  
                  
                  ## Then we ask the user for his/hers credentials.
                  user = raw_input('Username: ')
                  _pass = getpass.getpass('Password: ')
                  
                  ## If the user exists in the "db" and the decoded password
                  ## Matches the logged in user, it's a-ok :)
                  if user in db and db[user] == Encryption(_pass):
                      print('You logged in')
                  

                  添加更多用户

                  import pickle, hashlib
                  
                  def Encryption(data):
                      return hashlib.sha512(data).hexdigest()
                  
                  with open('database.db', 'rb') as fh:
                      db = pickle.load(fh)
                  
                  db['new_user'] = Encryption('password')
                  
                  with open('database.db', 'wb') as fh:
                      pickle.dump(db, fh)
                  

                  另一种方法是在添加用户时使用 sys.argv 从命令行获取用户名和密码,在这种情况下:

                  Another way would be to use sys.argv to get the username and password from the commandline when addings users, in that case:

                  import pickle, hashlib, sys
                  if len(sys.argv) < 3:
                      raise ValueError('Need two parameters, username and password')
                  
                  def Encryption(data):
                      return hashlib.sha512(data).hexdigest()
                  
                  with open('database.db', 'rb') as fh:
                      db = pickle.load(fh)
                  
                  db[sys.argv[1]] = Encryption(sys.argv[2])
                  
                  with open('database.db', 'wb') as fh:
                      pickle.dump(db, fh)
                  

                  我应该扩展这个答案并解释你应该 salt 密码 也是如此,而不仅仅是使用 SHA 哈希来存储它们.

                  I should expand on this answer and explain that you should salt passwords as well, and not just store them with a SHA hash.

                  另请注意,密码严格来说是不安全的".当存储在内存中时,因为没有 SecureString (更多)在写这篇文章时.但出于基本目的,这个答案仍然适用.

                  Also note that passwords are strictly speaking "unsafe" when stored in memory, as there is no SecureString (more) in Python as of writing this. But for basic purposes this answer still applies.

                  这篇关于密码保护 Python的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Adding config modes to Plotly.Py offline - modebar(将配置模式添加到 Plotly.Py 离线 - 模式栏)
                  Plotly: How to style a plotly figure so that it doesn#39;t display gaps for missing dates?(Plotly:如何设置绘图图形的样式,使其不显示缺失日期的间隙?)
                  python save plotly plot to local file and insert into html(python将绘图保存到本地文件并插入到html中)
                  Plotly: What color cycle does plotly express follow?(情节:情节表达遵循什么颜色循环?)
                  How to save plotly express plot into a html or static image file?(如何将情节表达图保存到 html 或静态图像文件中?)
                  Plotly: How to make a line plot from a pandas dataframe with a long or wide format?(Plotly:如何使用长格式或宽格式的 pandas 数据框制作线图?)

                  1. <i id='p0OBt'><tr id='p0OBt'><dt id='p0OBt'><q id='p0OBt'><span id='p0OBt'><b id='p0OBt'><form id='p0OBt'><ins id='p0OBt'></ins><ul id='p0OBt'></ul><sub id='p0OBt'></sub></form><legend id='p0OBt'></legend><bdo id='p0OBt'><pre id='p0OBt'><center id='p0OBt'></center></pre></bdo></b><th id='p0OBt'></th></span></q></dt></tr></i><div id='p0OBt'><tfoot id='p0OBt'></tfoot><dl id='p0OBt'><fieldset id='p0OBt'></fieldset></dl></div>

                    <small id='p0OBt'></small><noframes id='p0OBt'>

                    <legend id='p0OBt'><style id='p0OBt'><dir id='p0OBt'><q id='p0OBt'></q></dir></style></legend>
                        <bdo id='p0OBt'></bdo><ul id='p0OBt'></ul>

                        <tfoot id='p0OBt'></tfoot>

                            <tbody id='p0OBt'></tbody>