admin
admin
7880 2 0

bottle authentication 插件

Bottle-Cork

Cork provides a simple set of methods to implement Authentication and Authorization in web applications based on Bottle.

http://cork.firelet.net/
code https://github.com/FedericoCeratto/bottle-cork

下面是个更简单的示例(利用bottle.auth_basic):

import bottle

def check(user, passwd):
    if user == 'ben':
        return True
    return False

 @[bottle.route('/')](/name/bottle.route('/'))  @[bottle.auth_basic(ch](/name/bottle.auth_basic(ch) eck)
def index():
    print 'auth', bottle.request.auth
    print 'remote_addr', bottle.request.remote_addr
    return "Yay - you made it!"

if __name__ == '__main__':
    print "Starting server"
    bottle.run(host='0.0.0.0', port=8080, reloader=True) 

import urllib2, base64

(user, password) = ('ben', 'xyz')
request = urllib2.Request("http://localhost:8080/")
base64string = base64.encodestring('%s:%s' % (user, password)).replace('\n', '')
request.add_header("Authorization", "Basic %s" % base64string) 
result = urllib2.urlopen(request)
print result.read() 

摘菜 http://fledglingpolymath.tumblr.com/post/39977900894/basic-authentication-in-bottle-py

基于 cookie 的

def require_uid(fn):
    def check_uid(**kwargs):   
        cookie_uid = request.get_cookie('cookieName', secret='cookieSignature')

        if cookie_uid:
            //do stuff with a user object
            return fn(**kwargs)
        else:
            redirect("/loginagain")

    return check_uid


 @[route('/userstuff',](/name/route('/userstuff',) method='GET')
 @[require_uid](/name/require_uid)  @[view('app')](/name/view('app')) 
def app_userstuff():
    //doing things is what i like to do
    return dict(foo="bar")

摘菜 http://stackoverflow.com/questions/14087418/check-authentification-for-each-request-in-bottle

0

See Also

Nearby


Discussion (2)

admin
admin 2013-12-03 14:35

auth_basic

def auth_basic(check, realm="private", text="Access denied"):
    ''' Callback decorator to require HTTP auth (basic).
        TODO: Add route(check_auth=...) parameter. '''
    def decorator(func):
      def wrapper(*a, **ka):
        user, password = request.auth or (None, None)
        if user is None or not check(user, password):
          response.headers['WWW-Authenticate'] = 'Basic realm="%s"' % realm
          return HTTPError(401, text)
        return func(*a, **ka)
      return wrapper
    return decorator

0
admin
admin 2013-12-11 10:38

bottlepy-user-auth

from bottle import *
from bottle_user_auth import User

 @[root.route('/')](/name/root.route('/')) 
def index_page(): #displays index page
    user = User() #here and below - creates an instance of User class
    if user.loggedin:
        return 'You are an authenticated user'
    redirect('/login')

 @[root.post('/login')](/name/root.post('/login'))  @[view('login_page')](/name/view('login_page')) 
def login_page():
    #assume you have a login page with two fields: 
    #"email" and "password" and submit button

 @[root.post('/login')](/name/root.post('/login')) 
def user_login(): #getting credentials from POST request from login page
    user = User()

    if user.authenticate( 
            request.POST.get( 'email' ),
            request.POST.get( 'password' )
    ):
        #if authentication has been successful module will assing a cookie
        #with encripted user id from database to user
        redirect('/')

    redirect('/login/error')

https://github.com/bbrodriges/bottlepy-user-auth

0
Login Topics