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 で報告します。ファイルを変更しようとしましたが、パス名は長すぎてはいけません。
以上がFlaskへのアバターアップロードの詳しい説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。