當前位置: 首頁>>代碼示例>>Python>>正文


Python itsdangerous.URLSafeSerializer方法代碼示例

本文整理匯總了Python中itsdangerous.URLSafeSerializer方法的典型用法代碼示例。如果您正苦於以下問題:Python itsdangerous.URLSafeSerializer方法的具體用法?Python itsdangerous.URLSafeSerializer怎麽用?Python itsdangerous.URLSafeSerializer使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在itsdangerous的用法示例。


在下文中一共展示了itsdangerous.URLSafeSerializer方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: sign_data

# 需要導入模塊: import itsdangerous [as 別名]
# 或者: from itsdangerous import URLSafeSerializer [as 別名]
def sign_data(data, expires_in=None, **kw):
    """
    To sign url safe data.
    If expires_in is provided it will Time the signature
    :param data: (mixed) the data to sign
    :param expires_in: (int) in minutes. Time to expire
    :param kw: kwargs for itsdangerous.URLSafeSerializer
    :return:
    """
    if expires_in:
        expires_in *= 60
        s = URLSafeTimedSerializer2(secret_key=__CRYPT.get("secret_key"),
                                    expires_in=expires_in,
                                    salt=__CRYPT.get("salt"),
                                    **kw)
    else:
        s = itsdangerous.URLSafeSerializer(secret_key=__CRYPT.get("secret_key"),
                                           salt=__CRYPT.get("salt"),
                                           **kw)
    return s.dumps(data) 
開發者ID:mardix,項目名稱:assembly,代碼行數:22,代碼來源:asm.py

示例2: unsign_data

# 需要導入模塊: import itsdangerous [as 別名]
# 或者: from itsdangerous import URLSafeSerializer [as 別名]
def unsign_data(token,  **kw):
    """
    To unsign url safe data.
    If expires_in is provided it will Time the signature
    :param token:
    :param secret_key:
    :param salt: (string) a namespace key
    :param kw:
    :return:
    """
    if len(token.split(".")) == 3:
        s = URLSafeTimedSerializer2(secret_key=__CRYPT.get("secret_key"), salt=__CRYPT.get("salt"), **kw)
        value, timestamp = s.loads(token, max_age=None, return_timestamp=True)
        now = datetime.datetime.utcnow()
        if timestamp > now:
            return value
        else:
            raise itsdangerous.SignatureExpired(
                'Signature age %s < %s ' % (timestamp, now),
                payload=value,
                date_signed=timestamp)
    else:
        s = itsdangerous.URLSafeSerializer(secret_key=__CRYPT.get("secret_key"), salt=__CRYPT.get("salt"), **kw)
        return s.loads(token) 
開發者ID:mardix,項目名稱:assembly,代碼行數:26,代碼來源:asm.py

示例3: load_token

# 需要導入模塊: import itsdangerous [as 別名]
# 或者: from itsdangerous import URLSafeSerializer [as 別名]
def load_token(token):
    # Load unsafe because payload is needed for sig
    sig_okay, payload = URLSafeSerializer(current_app.config['SECRET_KEY']).loads_unsafe(token)

    if not payload:
        return None

    # User key *could* be stored in payload to avoid user lookup in db
    user = User.get_by_id(payload.get('id'))

    if not user:
        return None

    try:
        if BaseUser.signer(sha256(user.password).hexdigest()).loads(token):
            return user
        else:
            return None
    except BadSignature:
        return None 
開發者ID:scragg0x,項目名稱:realms-wiki,代碼行數:22,代碼來源:models.py

示例4: on_delete_signup

# 需要導入模塊: import itsdangerous [as 別名]
# 或者: from itsdangerous import URLSafeSerializer [as 別名]
def on_delete_signup(token):
    """Endpoint to delete signups via email"""
    try:
        s = URLSafeSerializer(get_token_secret())
        signup_id = ObjectId(s.loads(token))
    except BadSignature:
        return "Unknown token"

    deleteitem_internal('eventsignups', concurrency_check=False,
                        **{current_app.config['ID_FIELD']: signup_id})

    redirect_url = current_app.config.get('SIGNUP_DELETED_REDIRECT')
    if redirect_url:
        return redirect(redirect_url)
    else:
        return current_app.config['SIGNUP_DELETED_TEXT'] 
開發者ID:amiv-eth,項目名稱:amivapi,代碼行數:18,代碼來源:email_links.py

示例5: sign

# 需要導入模塊: import itsdangerous [as 別名]
# 或者: from itsdangerous import URLSafeSerializer [as 別名]
def sign(self, value, namespace="default"):
        return URLSafeSerializer(self._secret, namespace).dumps(value) 
開發者ID:simonw,項目名稱:datasette,代碼行數:4,代碼來源:app.py

示例6: unsign

# 需要導入模塊: import itsdangerous [as 別名]
# 或者: from itsdangerous import URLSafeSerializer [as 別名]
def unsign(self, signed, namespace="default"):
        return URLSafeSerializer(self._secret, namespace).loads(signed) 
開發者ID:simonw,項目名稱:datasette,代碼行數:4,代碼來源:app.py

示例7: connect

# 需要導入模塊: import itsdangerous [as 別名]
# 或者: from itsdangerous import URLSafeSerializer [as 別名]
def connect():
    global serializer, fernet
    crypto_info = settings.load()['database']['crypto']
    mongo_host = settings.load()['database']['mongo'].get('host', '127.0.0.1')
    mongo_port = settings.load()['database']['mongo'].get('port', '27017')
    serializer = URLSafeSerializer(crypto_info['key'])
    fernet = Fernet(crypto_info['fernet'])
    mongoengine.connect(name, host=mongo_host, port=mongo_port, tz_aware=True) 
開發者ID:mitre,項目名稱:cascade-server,代碼行數:10,代碼來源:database.py

示例8: encode

# 需要導入模塊: import itsdangerous [as 別名]
# 或者: from itsdangerous import URLSafeSerializer [as 別名]
def encode(something):
    """Encode something with SECRET_KEY."""
    secret_key = current_app.config.get('SECRET_KEY')
    s = URLSafeSerializer(secret_key)
    return s.dumps(something) 
開發者ID:Akagi201,項目名稱:learning-python,代碼行數:7,代碼來源:security.py

示例9: decode

# 需要導入模塊: import itsdangerous [as 別名]
# 或者: from itsdangerous import URLSafeSerializer [as 別名]
def decode(something):
    """Decode something with SECRET_KEY."""
    secret_key = current_app.config.get('SECRET_KEY')
    s = URLSafeSerializer(secret_key)
    try:
        return s.loads(something)
    except BadSignature:
        return None 
開發者ID:Akagi201,項目名稱:learning-python,代碼行數:10,代碼來源:security.py

示例10: get_serializer

# 需要導入模塊: import itsdangerous [as 別名]
# 或者: from itsdangerous import URLSafeSerializer [as 別名]
def get_serializer(secret_key=None):
    if secret_key is None:
        secret_key = current_app.config['SECRET_KEY']
    return URLSafeSerializer(secret_key) 
開發者ID:usgo,項目名稱:online-ratings,代碼行數:6,代碼來源:views.py

示例11: session

# 需要導入模塊: import itsdangerous [as 別名]
# 或者: from itsdangerous import URLSafeSerializer [as 別名]
def session(callback):
    cookie_name = 'session'
    serializer = URLSafeSerializer(conf['SECRET'])

    def inner(*args, **kwargs):
        data_raw = data = request.get_cookie(cookie_name)
        if data_raw:
            try:
                data = serializer.loads(data_raw)
            except (BadSignature, BadData):
                data = None

        if data:
            conf['USER'] = data['username']

        request.session = data or {}

        try:
            return callback(*args, **kwargs)
        finally:
            if request.session:
                save(request.session)
            elif not data_raw:
                pass
            else:
                response.delete_cookie(cookie_name)

    def save(session):
        cookie_opts = {
            # keep session for 3 days
            'max_age': 3600 * 24 * 3,

            # for security
            'httponly': True,
            'secure': request.headers.get('X-Forwarded-Proto') == 'https',
        }
        data = serializer.dumps(session)
        response.set_cookie(cookie_name, data, **cookie_opts)
    return inner 
開發者ID:naspeh,項目名稱:mailur,代碼行數:41,代碼來源:web.py

示例12: get_gopher_signing_serializer

# 需要導入模塊: import itsdangerous [as 別名]
# 或者: from itsdangerous import URLSafeSerializer [as 別名]
def get_gopher_signing_serializer(self, app):
        """
        This is almost the same serializer that the cookie session uses,
        except that it doesn't set an `expiration` time for the session.
        """
        if not app.secret_key:
            return None
        signer_kwargs = dict(
            key_derivation=self.key_derivation,
            digest_method=self.digest_method)
        return URLSafeSerializer(
            app.secret_key,
            salt=self.salt,
            serializer=self.serializer,
            signer_kwargs=signer_kwargs) 
開發者ID:michael-lazar,項目名稱:flask-gopher,代碼行數:17,代碼來源:flask_gopher.py

示例13: signer

# 需要導入模塊: import itsdangerous [as 別名]
# 或者: from itsdangerous import URLSafeSerializer [as 別名]
def signer(salt):
        return URLSafeSerializer(current_app.config['SECRET_KEY'] + salt) 
開發者ID:scragg0x,項目名稱:realms-wiki,代碼行數:4,代碼來源:models.py

示例14: generate_token

# 需要導入模塊: import itsdangerous [as 別名]
# 或者: from itsdangerous import URLSafeSerializer [as 別名]
def generate_token(self):
        s = URLSafeSerializer('secret-key')        
        self.token = s.dumps(self.address)
        return self.token 
開發者ID:RevengeComing,項目名稱:DemonHunter,代碼行數:6,代碼來源:models.py

示例15: sign_data

# 需要導入模塊: import itsdangerous [as 別名]
# 或者: from itsdangerous import URLSafeSerializer [as 別名]
def sign_data(data):
    """
    Serialize and sign data (likely to be put in a session cookie).
    Parameters
    ----------
    data : object
        Data to be serialized and signed.
    Returns
    -------
    str
        Encrypted data
    """
    s = URLSafeSerializer(app.secret_key)
    return s.dumps(data) 
開發者ID:interactiveaudiolab,項目名稱:CAQE,代碼行數:16,代碼來源:utilities.py


注:本文中的itsdangerous.URLSafeSerializer方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。