php中怎么传id,自己如何开发一款app?
今年六月的时候,萌生了开发一个记账 App 的想法,想去用自己的 App 记账,管理收支。那时正好在英国是考试周,放假后,我回到了国内,准备去实现我的计划。没想到这暑假很快就结束了,在这个暑假中经历的太多的事,准备了要去美国读研的考试,遇到了生命中的另一半,同时,也将 Costuary for iPhone 带到了这个世界。
Logo
说道为什么要开发这样一个 App ,因为笔者在 UK 读书,市面上很少有记账 App 能够实现实时汇率的换算,带有这个功能的 App 也是操作繁杂。所以要自己开发一个,功能并没有那么复杂的,并且能够满足自己在国外和国内生活需求的 App,所以自己编写了 iPhone 的客户端,为了获取汇率和 Excel 导出,又用 Java 设计和编写了 Costuary 的后端服务器。
比起今年年初开发的 Flat Weather,这个项目的代码量大约是他的十倍,需要实现众多的功能和模块。
这篇文章将会介绍一下 Costuary 的功能与我开发过程中的一些心得。
效果图设计
说到设计,两年前,我还是一个 Android 开发者,Google 的 Material Design 是我的最爱,所以,Costuary 采用了 Android 5.0 之后采用的 Material Design 设计。其中掺杂了一些我自己的设计,因为 Material Design 的控件有时候操作繁琐。
早在 5 月份的时候已经零零总总的用 Sketch 画出了这个产品的 UI 和图标,之后开始了漫长开发的过程。
Sketch交互
与去年开发的 Android 版不同,iPhone 版的 Costuary 采用了底部导航栏的设计,相比于 Android 通常使用的 Navigation Drawer 的抽屉布局,底部导航栏的设计即使在右手操作 iPhone 的时候都不会太费力。
UX功能Features
多币种记账Costuary 支持世界上主要货币的实时汇率转换,所有外汇在统计时会转换成主货币的数目,方便查看花销。
日历视图日历视图能够很直观的反映出哪一天有消费和收入。
图表说到记账软件,量化消费的图表无疑是重要的一环,Costuary 提供了饼状图来视觉化一段时间的花销。
多账户可以建立多个账户来表示自己的银行卡,支付宝,现金等等。
月预算可以看出本月的预算还有多少。
导出到 Excel如果想要进行更加详细的分析,可以使用导出功能将账本导出到 Excel。
备份与还原允许备份账本内容到 iCloud。
开发
去把一纸设计变成真正的产品,这是一个独立开发者应该具有的能力。只会写代码不只是我唯一掌握的,能够去设计出来自己想要的应用并且将他实现才是我在做的事情。
这款应用的开发并没有想象中的简单,需要自己去实现大量 Android UI 控件,很多圆角,阴影,字体,要慢慢的去调整,让控件适合 iPhone 的屏幕。整个应用的背后有 3 个关系型数据库来储存账户,账本与各种汇率。与以前开发的 Flat Weather 不同,Costuary 会产生大量的用户数据,所以整个软件架构的稳定性变得异常重要,需要设计一些机制来防止数据丢失与损坏。
Development
为了实现 App 获取每日的汇率,并且在 iPhone 上能够实现账本导出到 Excel ,我设计了一个服务器后端来处理这些繁杂的实物。每次 App 启动后会与我的服务器来更新最新的汇率。当用户选择导出时,账本会被发送到服务器上并处理为 Excel 发送到用户的邮箱里。
说到服务器,就不得不提到用户隐私了,因为导出到 Excel 功能需要将账本传到我的服务器上做进一步处理,很多人会觉得我侵犯了他的个人隐私。对此,为了保护我的权益与用户的权益,我撰写了 Costuary 软件许可及服务协议与 Costuary 隐私政策,这是我作为独立开发者这么多年后第一次去写许可协议。
Agreement资费
与我的其他产品一样,这款 App 依旧是免费供大家使用的,作为独立开发者,我们都知道,绝大多数用户不会去珍惜一个免费的产品。就像 Flat Weather 一样,虽然获得了很多人的支持,但是也收到了很多人的吐槽。在 Costuary 中依然设计了一个的捐助按钮,如果大家使用之后喜欢这个应用,请支持我将他维护下去。
Please donate me尾巴
Costuary for iPhone 是我开发出来过最大的软件体系。我相信,能够独立开发出来产品的人懂得不只是编程。一个人要去经历项目的全部生命周期:规划,设计,开发,运营,维护,营销,这些是我开发这么多产品所学会的。
现在的 Costuary 只是第一个版本,还有很多 iPhone 的特性没有来得及开发,以后会跟上的,比如 iPhone X 的适配,3D Touch、Today Widget、Touch ID 等等。
以前在少数派撰稿的时候,很多读者会来问我如何学习开发,我也特地去写过如何去学习编程,但我相信,真正想去学习的,想去为这个生态贡献出自己的一份力的人,自己都会找到学习的方法。我的专业是电子电器而不是软件工程,但是我不后悔当年去学习编程。
最后,还是感谢在背后默默支持我的人,我会不断地改进与提升,如果 Costuary 真的在记账方面给予了你便利,这是我莫大的荣幸。
如果想要了解我的更多作品可以访问我的个人博客 MikeTech,或者在少数派中阅读我以前写过的文章。今年年初也在 iPhone 上写过一个天气 App,天气应用 Flat Weather 的设计历程。
对了,关于记账有什么用,如何记账,如何养成记账的习惯。为什么每个月末都捉襟见肘,除了没钱,很可能是对财务管理的能力不强。想了解这一方面的知识,不妨看一看我派的付费阅读栏目:从零开始做好个人记账
PHP与NodeJS如何共用Session?
随着项目的发展,技术架构方案也是会慢慢演变的。比如说淘宝最早期是由单纯的PHP开发的站点,到现在单一架构模式已满足不了其发展需要,于是乎演变成了异构模式(即:多种技术的混合架构模式)。
现在市面上的开发语言众多,同一个产品线的多个子项目采用不同的编程语言开发也是很常见的。但对于不同语言开发的站点默认情况下Session是无法共用的,那么在异构模式下如何实现Session互通呢?下面给大家具体分析一下。
Session运行原理要想弄清楚不同语言间的Session互通问题,我们就要先了解Session的实现机制原理是什么。
大家都知道,HTTP协议本身是无状态的,客户端每次发出的请求在服务器端看来都是独立的,服务器端也无法得知哪些请求是同一个用户发出的。在这种机制下,有些需要状态保持的场景(如登录)就存在一些问题,于是就有了Cookie和Session。
举个例子来帮助大家理解一下:
因为HTTP协议无状态的特性,如果服务器端要辨识用户请求就需要给用户发一个“通行证”,拿到通行证的用户每次请求服务器时都会把这个通行证带上,这样一来服务器就知道拿着这个通行证的用户发出了哪些请求。那服务器是不是看到用户的“通行证”就直接放行呢?自然不是,对于某些操作,服务器端也要验证用户的“通行证”是否和服务器端存储的“用户档案”对得上。在这里,服务器端存储的用户档案就是Session,档案上的用户唯一编号就是SessionID,用户的唯一编号也会作为用户“通行证”的一部分发放给用户存储(存储在浏览器Cookie中)。
总结来说,Cookie是为了解决HTTP协议无状态的缺陷而推出的,而Session是一种在客户端和服务器端保持状态的解决方案。
PHP与Node.js如何实现Session共用?在这种异构模式下要实现Session共用,那就需要保证各自的SessionID是共用的,所以我给的解决方案如下:
1、PHP与Node.js客户端要保证存储SessionID的Cookie Name一致,如果Cookie的名称不统一也没关系,但要保证对于同一个客户的SessionID要一致。
2、服务器端的Session要集中到一处管理,这样PHP和Node.js都能获取到Session。比如说可以把Session存储在数据库中或者Redis中。
3、如果给Cookie作了加密,那要保证PHP与Node.js两端的加解密规则一致。
以上就是我的观点,对于这个问题大家是怎么看待的呢?欢迎在下方评论区交流 ~ 我是科技领域创作者,十年互联网从业经验,欢迎关注我了解更多科技知识!php怎么通过id获得数据库一行数据?
$link=mysql_connect("localhost","数据库帐号","数据库密码");
if(!$link) echo "没有连接成功!";
else echo "连接成功!";
mysql_select_db("数据库名称", $link);//选择数据库
$sql = "SELECT * FROM info where id=1";//SQL查询语句,指定你要获取的ID,info为表名
$rs = mysql_query($sql, $link);//获取数据集
$row=mysql_fetch_array($rs);
echo $row['uname'];//输出你要显示的字段名称
?>
帮你写了一段
a标签如何获取到php数据?
用js才用onclick 按你写的应该用url传值 <a href="dispsql.php?action=delete&id=这里放的是你数据库里对应记录的id">删除</a> <a href="dispsql.php?action=delete>全部删除</a> 在dispsql.php页面写删除语句,先接收上面传过来的条件 $action=GTE["action"]的值来选择执行删除还是删除全部 if($action=="delete"){ $id=GET["id"]; $sql = "delete from books where id={$id}"; mysql_query($sql); if($id==""){ 全部删除的语句 } }
如何解决weiphp注册用户无法登录后台管理?
在后台登陆,账号和密码都输入正确,但却提示出错:未授权访问 以下解决方案以SAE为例,进入应用管理界面,选择”代码管理“后单击”编辑代码“,我们将通过在线编辑代码 进入到ApplicationCommonConfconfig.php文件,发现管理员ID是写死的,只有一个,问题就在这了 我们可以再增加一个管理员ID,这个ID号就是新注册时生成的那个 完成上述步骤了还不行,还得找到判断处理的函数,进入ApplicationCommonCommonunction.php文件,可以看到这里对管理员ID进入了判断处理 我们再将新增的ID加进来即可,以下是处理办法 保存后再次登录后台就可以了