在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 問答/ Python問答
愛是癌 回答

這變化也忒快了吧。連問題的題目都變了


這是原題目的回答,多對多關(guān)系。

這是我設(shè)置的一個(gè)博客文章與tag多對多關(guān)系的模型,希望對你有所幫助。

class TagSpaces(db.Model):
    """多對多關(guān)系表"""
    __tablename__ = 'tag_spaces'
    tag_id = db.Column(db.Integer, db.ForeignKey('tags.id'), primary_key=True)
    article_id = db.Column(db.Integer, db.ForeignKey('articles.id'), primary_key=True)
    timestamp = db.Column(db.DateTime, default=datetime.utcnow)
class Tag(db.Model):
    """tag表"""
    __tablename__ = 'tags'
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(64), unique=True, index=True)
    tagged = db.relationship('TagSpaces',
                             foreign_keys=[TagSpaces.tag_id],
                             backref=db.backref('tagged', lazy='joined'),
                             lazy='dynamic',
                             cascade='all, delete-orphan')

    def __repr__(self):
        return '<Name %r>' % self.name
class Article(db.Model):
    """article 表"""
    __tablename__ = 'articles'
    id = db.Column(db.Integer, primary_key=True)
    title = db.Column(db.String(64), index=True)
    body = db.Column(db.Text)
    
    ......
    ......    
    ......
    
    tags = db.relationship('TagSpaces',
                           foreign_keys=[TagSpaces.article_id],
                           backref=db.backref('tags', lazy='joined'),
                           lazy='dynamic',
                           cascade='all, delete-orphan')

    def tag(self, tag):
    """寫文章的時(shí)候,直接往TagSpaces關(guān)聯(lián)表里添加需要關(guān)聯(lián)的 tag 標(biāo)簽"""
        if not self.is_tagging(tag):
            t = TagSpaces(tags=self, tagged=tag)
            db.session.add(t)

    def untag(self, tag):
    """從TagSpaces關(guān)聯(lián)表里刪除相關(guān)標(biāo)簽"""
        f = self.tags.filter_by(tag_id=tag.id).first()
        if f:
            db.session.delete(f)

    def is_tagging(self, tag):
    """判斷相關(guān)標(biāo)簽是否與文章進(jìn)行了關(guān)聯(lián)"""
        return self.tags.filter_by(tag_id=tag.id).first() is not None
    
    @property
    def taggeds(self):
    """以article類屬性的形式,返回文章的tag標(biāo)簽實(shí)例"""
        return Tag.query.join(TagSpaces, TagSpaces.tag_id == Tag.id).filter(TagSpaces.article_id == self.id)
    
article = Article.query.get(1) # 查詢一篇文章,返回一個(gè)實(shí)例對象
print article.taggeds # 返回該篇文章關(guān)聯(lián)的所有 tag 標(biāo)簽的實(shí)例對象。
for tag in article.taggeds:
    print tag.name
    # 循環(huán)返回所有的標(biāo)簽的名稱

或者,你可以看看我的博客項(xiàng)目 —— https://github.com/eastossifrage/pyblog/blob/master/app/models.py

墻頭草 回答

socket也就是套接字,負(fù)責(zé)的是數(shù)據(jù)的傳輸,數(shù)據(jù)的格式和數(shù)據(jù)是否加密是根據(jù)具體協(xié)議來的。
比如http協(xié)議就不需要加密,但是https協(xié)議就需要加密了,如果你自己開發(fā)了一套基于TCP/IP的加密協(xié)議,那么就根據(jù)你自己的協(xié)議規(guī)則加密解密。

朽鹿 回答

有很多小問題,比如

1        conn,address = server.accept()
2        rec_buf=conn.recv(1024)
3        //make some handle here, store this connection in global data
4        conn.setblocking(0)
5        conn.sendall("pass")

第 2 行將阻塞整個(gè)線程,直到對方發(fā)送數(shù)據(jù),或連接斷開。
第 5 行因?yàn)闆]有預(yù)先判斷 conn 是否可寫,操作可能失敗。

建議使用 asyncio 改寫,參考

# -*- coding: utf-8 -*-
import asyncio


async def handle_server(reader, writer):
    data = await reader.readexactly(10)
    print('recv1: {}'.format(data.decode()))
    writer.write('pass'.encode())
    writer.close()


async def handle_client(reader, writer):
    data = await reader.readexactly(4)
    if data.decode() == 'OPEN':
        writer.write('success'.encode())
    writer.close()


def new_listener(loop, ip, port, handler):
    coro = asyncio.start_server(handler, ip, port, loop=loop)
    return loop.run_until_complete(coro)


if __name__ == "__main__":
    loop = asyncio.get_event_loop()
    new_listener(loop, '127.0.0.1', 8322, handle_server),
    new_listener(loop, '127.0.0.1', 12355, handle_client),
    loop.run_forever()
有你在 回答

后面是空格''啊。
因?yàn)槟阌?個(gè)數(shù)字分割的。
相當(dāng)于是'BIT'+6個(gè)數(shù)字+TSU+6個(gè)數(shù)字+''

誮惜顏 回答

啥?你打了 supervisor 標(biāo)簽?supervisor 支持 Windows??

你的服務(wù)不能訪問 D3D 唄。服務(wù)的運(yùn)行環(huán)境和普通進(jìn)程是不一樣的嘛。你去看看 MSDN 文檔,看看服務(wù)要怎么訪問 D3D。

乖乖噠 回答

你的問題之前有人回答過的, 戳此,簡而言之,一般是為了防止cdn的鏈接地址被人手工構(gòu)造,從而減輕cdn被人惡意創(chuàng)建緩存的幾率。

P.S.

cdn服務(wù)器自己構(gòu)造的地址一般是 url+自己的密鑰,然后md5加密一下放在url中一起返回,形如 https://cdn.some.com/test111.png?v=234242342&md5=d63d0b4fabf9e99002d0e0641c4ddfce
這個(gè)密鑰對外是保密的,
用于cdn服務(wù)端接收到請求驗(yàn)證url的合法性時(shí)使用,即取出url中的https://cdn.some.com/test111.png?v=234242342 + 密鑰字符串,一起用md5加密后,看看是不是等于url中的md5簽名,相等則證明這個(gè)url請求是合法的,否則認(rèn)為是客戶端自己編造的。

<router-view/>?什么東西,,去掉試一下。

菊外人 回答

用你的程序我成功登錄了,試試把chrome瀏覽器全部關(guān)閉后,運(yùn)行你的程序。我的chromedriver.exe在C:\Windows\System32

款爺 回答

可以的。 qt有可視化的ui設(shè)計(jì)編輯器。 文件格式為.ui,pyqt也有現(xiàn)成的.ui轉(zhuǎn) .py的命令行工具。

建議把
UPLOAD_FOLDER = '/var/www/cardShow/app/static'
改成
UPLOAD_FOLDER = '/var/www/cardShow/app/static/'

薄荷綠 回答

大哥你仔細(xì)看你的代碼,你要return的data被for循環(huán)覆蓋了,第二個(gè)代碼你用了print(),當(dāng)然每次循環(huán)只是把data打印出來了

萌二代 回答

先用get方法把網(wǎng)頁get下來,才有你看到的登錄界面
然后你提交用戶名密碼的時(shí)候應(yīng)該是post的方法。
如果你提交的時(shí)候還是get方法,那他的后臺就有漏洞,是get還是post取決于后臺程序,而不是爬蟲程序

圖片描述

話寡 回答

res.render已經(jīng)輸出渲染視圖了,此時(shí)不應(yīng)該再調(diào)用next,會傳遞到下一個(gè)方法重復(fù)輸出

渲染效果取決于你的標(biāo)簽。

<html>
    <body>
        <!--這個(gè)沒有效果-->
        <p>   abc   </p>

        <!--這個(gè)有效果-->
        <p>--<span>   abc   </span>--</p>

        <!--這個(gè)也有效果-->
        <pre>   abc   </pre>
    </body>
</html>
墨沫 回答

這是安全機(jī)制使然,很多網(wǎng)站都有類似要求的。

乖乖瀦 回答

1.看你現(xiàn)在的代碼A和B沒有任何關(guān)聯(lián)關(guān)系,如果B是A的組件的話可以通過props傳入
2.如果你只是想把A的方法作為公共的方法,那么可以寫一個(gè)公共的js,不需要繼承component,直接在b里import,然后就可以調(diào)用b的方法了,但是這個(gè)時(shí)候調(diào)用的this并不是指向B組件的實(shí)例,所以調(diào)用的時(shí)候用類似
change.call(this)這種