Flaskへのアバターアップロードの詳しい説明

零下一度
リリース: 2017-07-17 14:00:07
オリジナル
1579 人が閲覧しました

Flask Web開発の本はほぼ完成しており、後で見直す必要がありますが、自分で作ったブログはいつも少し雑に感じるので、新しい機能の開発に頭を使っています

今日は最も基本的な機能を考えました、カスタムアバター

このような機能は、2つの基本的な機能ブロックに設計されています

1: ファイルをアップロードして保存する方法

2: ユーザーモデルでアバター写真とユーザーをリンクする方法

オンラインで確認した2番目の質問 議論の結果1 つ目は、画像をバイナリに変換してデータベースに保存する方法です。

アバターを自分でアップロードする方法です。実際には、データベースがこのパスを保存し、それがどのように実装されるかを見てみましょう。

データベースの設定は次のとおりです


user_image=db.Column(db.String(252),nullable=True)
ログイン後にコピー

フォームフォームのデザイン:

avatar=FileField('头像')
ログイン後にコピー

バックエンドの実装コード

 avatar=request.files['avatar']
 fanme=avatar.filename
 upfile=os.getcwd()+('/app/static/avatar/')
 ALLOWER_EXIT=['pang','jpg','jpeg','jig']
flag='.' in fanme and fanme.split('.')[1] in ALLOWER_EXITif not flag:     return render_template('editperson.html',form=form)
 avatar.save('{}{}{}'.format(upfile,user.username,fanme))
 user.user_image='/static/avatar/{}{}'.format(user.username,fanme)
 db.session.add(user)
ログイン後にコピー

ストレージパスは

/static/avatar/,支持格式 pang、jpg、jpeg等格式,这个可以根据自己的需求进行设置。 
存储后会在数据库存储一个路径
最后实现后数据库
ログイン後にコピー

次は正面-表示終了

{% if username.user_image%}<img   src="{{username.user_image}}" style="height:80px;">{%else%}<img src="/static/img/0.jpg" style="height:70px;width:80px">{%endif%}
ログイン後にコピー

ここで説明しますが、バックエンドでアバターをアップロードするためのコードは、ファイルが存在しないことを示すエラーを Windows で報告します。ファイルを変更しようとしましたが、パス名は長すぎてはいけません。

短いパス名でも問題ありませんが、エラーを報告するだけでも問題ありません。 Windows開発には多くの欠点がありますが、Ubuntuでの実装には問題ありません

以上がFlaskへのアバターアップロードの詳しい説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート