Flask愛家租房--發布新房源(保存房屋圖片)

0.頁面展示效果

1)首先房東填寫房屋信息;
在這里插入圖片描述
2)當房東填寫發布的房源信息之后,隱藏(hide)剛才填寫信息的界面,同時顯示(show)上傳房屋圖片的界面。

在這里插入圖片描述

1.后端代碼

@api.route("/houses/image", methods=["POST"])
@login_required
def save_house_image():"""保存房屋的圖片參數 圖片 房屋的id"""image_file = request.files.get("house_image")house_id = request.form.get("house_id")if not all([image_file, house_id]):return jsonify(errno=RET.PARAMERR, errmsg="參數錯誤")# 判斷house_id正確性try:house = House.query.get(house_id)except Exception as e:current_app.logger.error(e)return jsonify(errno=RET.DBERR, errmsg="數據庫異常")if house is None:  # if not house:return jsonify(errno=RET.NODATA, errmsg="房屋不存在")image_data = image_file.read()# 保存圖片到七牛中try:file_name = storage(image_data)except Exception as e:current_app.logger.error(e)return jsonify(errno=RET.THIRDERR, errmsg="保存圖片失敗")# 保存圖片信息到數據庫中house_image = HouseImage(house_id=house_id, url=file_name)db.session.add(house_image)# 處理房屋的主圖片if not house.index_image_url:house.index_image_url = file_namedb.session.add(house)try:db.session.commit()except Exception as e:current_app.logger.error(e)db.session.rollback()return jsonify(errno=RET.DBERR, errmsg="保存圖片數據異常")image_url = constants.QINIU_URL_DOMAIN + file_namereturn jsonify(errno=RET.OK, errmsg="OK", data={"image_url": image_url})

2.前端html代碼

在這里插入圖片描述

            <form id="form-house-image" action="/api/house/image" method="post" enctype="multipart/form-data"><input type="hidden" name="house_id" id="house-id" value=""><li><div class="house-title"><h3>添加圖片</h3></div><div class="house-content"><div class="house-image-cons"></div><div class="form-group"><label for="house-image">選擇圖片</label><input type="file" accept="image/*" name="house_image" id="house-image"></div><input type="submit" class="btn btn-success" value="上傳"></div></li></form>

3.前端js代碼

在這里插入圖片描述

$("#form-house-image").submit(function (e) {e.preventDefault();$(this).ajaxSubmit({url: "/api/v1.0/houses/image",type: "post",dataType: "json",headers: {"X-CSRFToken": getCookie("csrf_token"),},success: function (resp) {if (resp.errno == "4101") {location.href = "/login.html";} else if (resp.errno == "0") {$(".house-image-cons").append('<img src="' + resp.data.image_url +'">');} else {alert(resp.errmsg);}}})})

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/452627.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/452627.shtml
英文地址,請注明出處:http://en.pswp.cn/news/452627.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

數字的處理 :小數點四舍五入

js取float型小數點后兩位數的方法 轉載 發布時間&#xff1a;2014年01月18日 17:03:32 投稿&#xff1a;shangke 我要評論 js中取小數點后兩位方法最常用的就是四舍五入函數了&#xff0c;前面我介紹過js中四舍五入一此常用函數&#xff0c;這里正好用上&#xff0c;下面…

如何成為一名優秀的C程序員

問題的提出 每過一段時間我總會收到一些程序員發來的電子郵件&#xff0c;他們會問我是用什么編程語言來編寫自己的游戲的&#xff0c;以及我是如何學習這種編程語言的。因此&#xff0c;我認為在這篇博文里列出一些有關C語言的最佳讀物應該能幫到不少人。如果你知道其它的優秀…

CFS調度器

一、前言 隨著內核版本的演進&#xff0c;其源代碼的膨脹速度也在遞增&#xff0c;這讓Linux的學習曲線變得越來越陡峭了。這對初識內核的同學而言當然不是什么好事情&#xff0c;滿腔熱情很容易被當頭澆滅。我有一個循序漸進的方法&#xff0c;那就是先不要看最新的內核&#…

oracle索引分類與區分,深入理解Oracle表(6):堆組織表(HOT)和索引組織表(IOT)的區別...

摘要&#xff1a;堆表&#xff1a;又稱堆組織表&#xff0c;常用的表類型&#xff0c;以堆的方式管理&#xff0c;當增加數據時&#xff0c;將使用段中第一個適合數據大小的空閑空間。當刪除數據時&#xff0c;留下的空間允許以后的DML操作重用。 堆組織表(heap table)應用中99…

Flask愛家租房--發布新房源(總結)

重點總結 學習過程中&#xff0c;發現house_id貫穿兩個接口內容&#xff0c;現對后端邏輯部分做以下總結&#xff1a; 1&#xff09;房東首先在前端填寫房屋的基本信息&#xff0c;此時通過newhouse.js文件$("#form-house-info").submit(function (e) {…}進行處理&…

關系的三類完整性約束

規則2.1實體完整性規則&#xff08;Entity Integrity&#xff09;若屬性A是基本關系R的主屬性&#xff0c;則屬性A不能取空值空值就是“不知道”或“不存在”或“無意義”的值例&#xff1a; 選修&#xff08;學號&#xff0c;課程號&#xff0c;成績&#xff09; “學號、課…

[QNAP crontab 定時執行程式

注意要自動執行的 sh 檔不要放在 /root 裡, 不然韌體更新後檔案會不見, 要放在個人帳號的資料夾&#xff0c;例如 /share/homes/帳號/ QNAP 的 crontab 放在 /etc/config/crontabvi /etc/config/crontab 例如要每日5:00執行 backup.sh 的話&#xff0c;加上這行 00 5 * * * /s…

調整標志位方法oracle,面試題(二)(示例代碼)

1.查找/us/oc al/nginx/ogs下更改時間在7天前以log 后極的文件井移動到sr/oca/nginx/log/backup下(至少兩種方法)2. Centos 查看某個進程的環境安量3.簡述DNS迭代查詢和遞歸直詢的區別4.簡述TCP三次握手過程以及涉及到的狀態(可畫草圖) ?5.統計TCP連接狀態(至少兩種方法)6.發現…

國際最具潛力IT專業認證

正如很多的爭論一樣&#xff0c;IT認證也是現在爭論的熱點&#xff0c;在IT專業人士的世界里&#xff0c;IT認證對于其職業規劃有著很大的影響。在時下究竟哪個認證才具有最大意義呢&#xff1f;本文羅列了十個最具潛力的技術認證&#xff0c;一起來看看都有哪些吧&#xff01;…

關系代數

關系代數是一種抽象的查詢語言&#xff0c;它用對關系的運算來表達查詢關系代數運算對象是關系運算結果亦為關系關系代數的運算符有兩類&#xff1a;集合運算符和專門的關系運算符

設計模式的六大原則

設計模式是一套被反復使用、多數人知曉的、經過分類編目的、代碼設計經驗的總結。使用設計模式是為了可重用代碼、讓代碼更加容易被他人理解、保證代碼可靠性。設計模式是代碼編制真正工程化&#xff08;工程化即系統化、模塊化、規范化的一個過程。指將具有一定規模數量的單個…

作業7

stuNum 201709090072 print(年級是&#xff1a;stuNum[0:4]) print(專業編號是: stuNum[4:9]) print(序號是: stuNum[-3:]) stuNum 440982201812111876 print(所在省市&#xff1a;stuNum[0:2]) print(所在地區&#xff1a;stuNum[2:4]) print(所在縣區&#xff1a;stuNum[4:…

linux進程退出沒有log,Linux下應用進程消失原因分析-Go語言中文社區

應用部署在Linux環境下&#xff0c;如果出現未知原因導致應用進程被殺(應用日志中沒有任何異常現象&#xff0c;日志出現中斷現象)&#xff0c;如果對于進程消失原因沒有特別明確的方向&#xff0c;可以考慮從系統日志(/var/log/messages)方面查找原因。 命令參考egrep -i kill…

數學是成就卓越開發人員的必備技能

編者按&#xff1a;原文作者Alan Skorkin是一名軟件開發人員&#xff0c;他在博客中分享對軟件開發相關的心得&#xff0c;其中有很多優秀的文章&#xff0c;本文就是其中一篇&#xff0c;作者認為&#xff1a;成為優秀的開發人員&#xff0c;可以沒有數學技能&#xff0c;但成…

Flask愛家租房--celery(總結)

0. celery整體邏輯圖 個人理解為&#xff1a;此處的客戶端client與以往定義的客戶端&#xff08;前端&#xff09;并不一樣&#xff0c;角色相當于以往的后端邏輯處理代碼&#xff0c;即發布任務的一方&#xff0c;只是相當于處理者worker而言是客戶端。 1.準備工作&#xff1…

linux端口514啟動,Linux查看端口使用狀態及啟動(示例代碼)

Netstat -tln 命令是Linux查看端口使用情況/etc/init.d/vsftp start 是用來啟動ftp端口~&#xff01;看文件/etc/servicesnetstatLinux查看端口查看已經連接的服務端口(ESTABLISHED)netstat -aLinux查看端口查看所有的服務端口(LISTEN&#xff0c;ESTABLISHED)sudo netstat -ap…

window服務器開站點(不通用)

此文章為記錄自己的配置流程&#xff0c;其他人不通用 網站服務器&#xff1a;Windows server 2008 R2 (IIS6.1) Asp.net 數據庫服務器&#xff1a;Windows server 2008 R2 SQL Server 2008 R2 1.解析域名到服務器&#xff0c;如&#xff1a;www.test.com 2.登錄網站服務器&a…

【轉載】優秀文章轉載集合

Spring Spring Cache 注釋驅動的 Spring cache 緩存介紹使用 Spring 2.5 注釋驅動的 IoC 功能虛擬化 libvirt kvm 虛擬機上網 – Bridge橋接KVM詳解&#xff0c;太詳細太深入了&#xff0c;經典Tomcat Linux機器同時運行兩個tomcat點評&#xff1a;主要是那張圖片的配置 Nginx …

Flask愛家租房--celery(發送驗證短信)

0.配置文件 # coding:utf-8BROKER_URL "redis://127.0.0.1:6379/1" CELERY_RESULT_BACKEND redis://127.0.0.1:6379/21.啟動文件 # coding:utf-8from celery import Celery from ihome.tasks import config# 定義celery對象 celery_app Celery("ihome"…